我正在尝试使用sed删除空行:
sed '/^$/d'
但我运气不佳。
例如,我有这样几行:
xxxxxx
yyyyyy
zzzzzz
我希望它是这样的:
xxxxxx
yyyyyy
zzzzzz
这个的代码应该是什么?
我正在尝试使用sed删除空行:
sed '/^$/d'
但我运气不佳。
例如,我有这样几行:
xxxxxx
yyyyyy
zzzzzz
我希望它是这样的:
xxxxxx
yyyyyy
zzzzzz
这个的代码应该是什么?
当前回答
我相信这是最简单和最快的方法:
cat file.txt | grep .
如果你需要忽略所有空白行,那么试试这个:
cat file.txt | grep '\S'
例子:
s="\
\
a\
b\
\
Below is TAB:\
\
Below is space:\
\
c\
\
"; echo "$s" | grep . | wc -l; echo "$s" | grep '\S' | wc -l
输出
7
5
其他回答
你也可以使用"grep"来做类似的事情:
egrep -v "^$" file.txt
借助这里的公认答案和上面的公认答案,我使用了:
$ sed 's/^ *//; s/ *$//; /^$/d; /^\s*$/d' file.txt > output.txt
`s/^ *//` => left trim
`s/ *$//` => right trim
`/^$/d` => remove empty line
`/^\s*$/d` => delete lines which may contain white space
这涵盖了所有的基础,完美地满足了我的需求。向最初的海报致敬@肯特和@凯文
您很可能会看到意想不到的行为,因为您的文本文件是在Windows上创建的,因此行序列的末尾是\r\n。在运行sed或use之前,可以使用dos2unix将其转换为UNIX样式的文本文件
sed -r "/^\r?$/d"
无论回车符是否存在,都要删除空行。
NF是awk的命令,可用于删除文件中的空行 awk NF文件名 通过使用sed Sed -r "/^\r?美元/ d”
另一个没有sed, awk, perl等的选项
strings $file > $output
字符串-打印文件中可打印字符的字符串。