我在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 -e '^$' foo.txt

e选项允许正则表达式模式进行匹配。

^$周围的单引号使它适用于shell。其他shell只接受单引号或双引号。

更新:这适用于一个有空行或“全空白”的文件(如windows行带\r\n样式的行结束符),而上面只删除有空行和unix样式行结束符的文件:

grep -v -e '^[[:space:]]*$' foo.txt

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

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

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

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

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

awk 'NF' foo.txt

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

grep -v '^ *$' foo.txt

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

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

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

与之前的答案相同:

grep -v -e '^$' foo.txt

这里,grep -e表示grep的扩展版本。'^$'表示^(行首)和$(行尾)之间没有任何字符。'^'和'$'是正则表达式字符。

因此,命令grep -v将打印所有不匹配此模式的行(^和$之间没有字符)。

这样,空行就被消除了。