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


当前回答

Use:

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

或者简单地awk:

awk 'NF' file

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

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

其他回答

Use:

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

或者简单地awk:

awk 'NF' file

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

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

使用Perl:

perl -ne 'print if /\S/'

\S表示匹配非空字符。

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

 grep -v "^#" file.txt | grep -v ^[[:space:]]*$

Egrep -v "^\s\s+"

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

+复制当前模式。

^表示开始

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

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