gpt4 book ai didi

regex - 使用 sed 删除从第 n 列开始到下一个非空白区域的所有空白区域

转载 作者:行者123 更新时间:2023-12-02 08:31:40 25 4
gpt4 key购买 nike

我正在尝试使用 sed/awk/等。在 Cygwin 上删除在简单文本文件中从指定位置开始到下一个非空白字符的所有行中找到的所有空格,保留指定位置之前和下一个非空白字符之后的所有空白.

我对 sed 的使用已经够多了,知道它是可行的,但我无法自己弄明白或找到正确的解决方案。我的问题似乎比我发现的大多数示例都简单,但我花了足够多的时间,最终愿意承认我需要一些指导。

以下之前和之后的内容有望帮助解释我正在尝试做的事情。在这种情况下,我想执行从“L”列开始的操作。

BEFORE:    
The quick brown fox jumped high.
Mary had a little lamb and ate it
Tom, Dick and Harry feel lost.

123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ

AFTER:
The quick brown fox jumped high.
Mary had a little lamb and ate it
Tom, Dick and Harry feel lost.

如有任何建议,我们将不胜感激。

最佳答案

这是一个使用正则表达式在 sed 中实现范围量词 { n } 的解决方案。

#!/bin/sh
STRING=$(cat <<EOF
The quick brown fox jumped high.
Mary had a little lamb and ate it
Tom, Dick and Harry feel lost.
EOF
)
echo "$STRING" | sed -r 's/^(.{20}) */\1/g'

输出

The quick brown fox jumped high.
Mary had a little lamb and ate it
Tom, Dick and Harry feel lost.

关于regex - 使用 sed 删除从第 n 列开始到下一个非空白区域的所有空白区域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26070682/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com