ars*_*ars 274
请尝试以下方法:
grep -v -e '^$' foo.txt
Run Code Online (Sandbox Code Playgroud)
该-e选项允许正则表达式模式进行匹配.
单引号^$使它适用于Cshell.其他炮弹会对单引号或双引号感到满意.
更新:这适用于我的空白行或"所有空格"文件(如带有"\ r \n"样式行结尾的窗口行),而上面只删除带有空行和unix样式行结尾的文件:
grep -v -e '^[[:space:]]*$' foo.txt
Run Code Online (Sandbox Code Playgroud)
Fre*_*lly 58
把事情简单化.
grep . filename.txt
Run Code Online (Sandbox Code Playgroud)
gho*_*g74 28
$ dos2unix file
$ grep -v "^$" file
Run Code Online (Sandbox Code Playgroud)
或者只是简单的awk
awk 'NF' file
Run Code Online (Sandbox Code Playgroud)
如果您没有dos2unix,那么您可以使用tr之类的工具
tr -d '\r' < "$file" > t ; mv t "$file"
Run Code Online (Sandbox Code Playgroud)
Sep*_*ero 15
grep -v "^[[:space:]]*$"
The -v makes it print lines that do not completely match
===Each part explained===
^ match start of line
[[:space:]] match whitespace- spaces, tabs, carriage returns, etc.
* previous match (whitespace) may exist from 0 to infinite times
$ match end of line
Run Code Online (Sandbox Code Playgroud)
运行代码 -
$ echo "
> hello
>
> ok" |
> grep -v "^[[:space:]]*$"
hello
ok
Run Code Online (Sandbox Code Playgroud)
为了更多地了解这是如何/为什么这样做,我建议阅读正则表达式.http://www.regular-expressions.info/tutorial.html
小智 6
如果您有连续多个空行的序列,并且希望每个序列只有一个空行,请尝试
grep -v "unwantedThing" foo.txt | cat -s
Run Code Online (Sandbox Code Playgroud)
cat -s抑制重复的空输出行。
你的输出将来自
match1
match2
Run Code Online (Sandbox Code Playgroud)
到
match1
match2
Run Code Online (Sandbox Code Playgroud)
原始输出中的三个空行将被压缩或“压缩”为一个空行。
文件中的行是否包含空格字符?
如果是这样那么
grep "\S" file.txt
否则
grep . file.txt
答案来自: https: //serverfault.com/a/688789