我正在尝试使用sed删除空行:

sed '/^$/d'

但我运气不佳。

例如,我有这样几行:

xxxxxx


yyyyyy


zzzzzz

我希望它是这样的:

xxxxxx
yyyyyy
zzzzzz

这个的代码应该是什么?


当前回答

你可以说:

sed -n '/ / p' filename    #there is a space between '//'

其他回答

我的bash特定的答案是建议使用perl替换操作符与全局模式g标志,如下所示:

$ perl -pe s'/^\n|^[\ ]*\n//g' $file
xxxxxx
yyyyyy
zzzzzz

这个答案说明了计算空行中是否有空格([\]*),以及使用|分隔多个搜索词/字段。在macOS High Sierra和CentOS 6/7上测试。

仅供参考,OP的原始代码sed '/^$/d' $文件在高性能超级计算集群的macOS High Sierra和CentOS 6/7 Linux的bash Terminal中正常工作。

sed

' / ^[[:空间:]]*美元/ d ' ' / ^ \ s *美元/ d ' ' / ^ $ / d ' - n ' / ^ \ s *美元/ !p '

grep

. - v“^ $” - v ' ^ \ s * $ ' - v " ^[[:空间:]]*美元”

awk

/。/ “NF” “长度” '/^[\t]*$/ {next;} {print}' ”!/ ^ \ [t] * $ / '

您正在尝试的命令是正确的,只需使用-E标志。

sed -E '/^$/d'

-E标志使sed捕获扩展正则表达式。更多信息请点击这里

你可以说:

sed -n '/ / p' filename    #there is a space between '//'

在“空”行中可能有空格或制表符。使用POSIX类和sed删除所有只包含空格的行:

sed '/^[[:space:]]*$/d'

一个使用ERE的短版本,例如gnu sed:

sed -r '/^\s*$/d'

(注意sed不支持PCRE。)