我在Linux中尝试了grep -v '^$',但没有工作。该文件来自Windows文件系统。
当前回答
与之前的答案相同:
grep -v -e '^$' foo.txt
这里,grep -e表示grep的扩展版本。'^$'表示^(行首)和$(行尾)之间没有任何字符。'^'和'$'是正则表达式字符。
因此,命令grep -v将打印所有不匹配此模式的行(^和$之间没有字符)。
这样,空行就被消除了。
其他回答
awk 'NF' file-with-blank-lines > file-with-no-blank-lines
此代码删除空行和以“#”开头的行
grep -v "^#" file.txt | grep -v ^[[:space:]]*$
试试下面的方法:
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
Use:
$ dos2unix file
$ grep -v "^$" file
或者简单地awk:
awk 'NF' file
如果你没有dos2unix,那么你可以使用像tr这样的工具:
tr -d '\r' < "$file" > t ; mv t "$file"