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


当前回答

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

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

其他回答

使用Perl:

perl -ne 'print if /\S/'

\S表示匹配非空字符。

文件中的行中有空白字符吗?

如果是,那么

grep “\S” 文件.txt

否则

握。文件.txt

得到的答案: https://serverfault.com/a/688789

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

awk 'NF' foo.txt

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

grep -v '^ *$' foo.txt

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

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

grep -v '^\s*$' foo.txt
awk 'NF' file-with-blank-lines > file-with-no-blank-lines

保持简单。

grep . filename.txt