我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。


当前回答

Egrep -v "^\s\s+"

Egrep已经做了正则表达式,\s是空白。

+复制当前模式。

^表示开始

其他回答

我努力尝试,但这似乎工作(假设\r在这里咬你):

printf "\r" | egrep -xv "[[:space:]]*"

我更喜欢使用egrep,尽管在我的测试中,您的方法工作得很好(尽管在我的测试中没有引号)。这个方法也奏效了:

egrep -v "^(\r?\n)?$" filename.txt

Use:

grep pattern filename.txt | uniq

如果在一行中有多个空行序列,并且每个序列只希望有一个空行,请尝试

grep -v "unwantedThing" foo.txt | cat -s

Cat -s抑制重复的空输出行。

你的输出会从

match1



match2

to

match1

match2

原始输出中的三个空行将被压缩或“压缩”为一个空行。

使用Perl:

perl -ne 'print if /\S/'

\S表示匹配非空字符。