我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
此代码删除空行和以“#”开头的行
grep -v "^#" file.txt | grep -v ^[[:space:]]*$
其他回答
我努力尝试,但这似乎工作(假设\r在这里咬你):
printf "\r" | egrep -xv "[[:space:]]*"
我更喜欢使用egrep,尽管在我的测试中,您的方法工作得很好(尽管在我的测试中没有引号)。这个方法也奏效了:
egrep -v "^(\r?\n)?$" filename.txt
Egrep -v "^\s\s+"
Egrep已经做了正则表达式,\s是空白。
+复制当前模式。
^表示开始
如果在一行中有多个空行序列,并且每个序列只希望有一个空行,请尝试
grep -v "unwantedThing" foo.txt | cat -s
Cat -s抑制重复的空输出行。
你的输出会从
match1
match2
to
match1
match2
原始输出中的三个空行将被压缩或“压缩”为一个空行。
的确,使用grep -v -e '^$'可以工作,但是它不能删除有1个或多个空格的空行。我发现删除空行最简单的答案是使用awk。下面是对上面awk的修改:
awk 'NF' foo.txt
但由于这个问题是为了使用grep,我将回答以下问题:
grep -v '^ *$' foo.txt
注意:^和*之间有空格。
或者你可以用\s来表示空格,就像这样:
grep -v '^\s*$' foo.txt