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


当前回答

的确,使用grep -v -e '^$'可以工作,但是它不能删除有1个或多个空格的空行。我发现删除空行最简单的答案是使用awk。下面是对上面awk的修改:

awk 'NF' foo.txt

但由于这个问题是为了使用grep,我将回答以下问题:

grep -v '^ *$' foo.txt

注意:^和*之间有空格。

或者你可以用\s来表示空格,就像这样:

grep -v '^\s*$' foo.txt

其他回答

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

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

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

你的输出会从

match1



match2

to

match1

match2

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

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

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

Use:

$ dos2unix file
$ grep -v "^$" file

或者简单地awk:

awk 'NF' file

如果你没有dos2unix,那么你可以使用像tr这样的工具:

tr -d '\r' < "$file" > t ; mv t "$file"

此代码删除空行和以“#”开头的行

 grep -v "^#" file.txt | grep -v ^[[:space:]]*$
awk 'NF' file-with-blank-lines > file-with-no-blank-lines