我正在尝试使用sed删除空行:

sed '/^$/d'

但我运气不佳。

例如,我有这样几行:

xxxxxx


yyyyyy


zzzzzz

我希望它是这样的:

xxxxxx
yyyyyy
zzzzzz

这个的代码应该是什么?


当前回答

Sed '/^$/d'应该是好的,你期望修改文件到位吗?如果是这样,您应该使用-i标志。

也许这些行不是空的,如果是这样的话,看看这个问题从txtfiles中删除空行,从行开始和行结束删除空格,我相信这就是你想要达到的目的。

其他回答

借助这里的公认答案和上面的公认答案,我使用了:

$ 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

这涵盖了所有的基础,完美地满足了我的需求。向最初的海报致敬@肯特和@凯文

这也适用于awk。

awk '!/^$/' file
xxxxxx
yyyyyy
zzzzzz

如果你想使用现代Rust工具,你可以考虑:

ripgrep: Cat数据文件| rg '。'带空格的行被认为是非空的 cat datafile | rg '\S'行带空格被认为是空的 rg '\S'带空格的数据文件行被认为是空的(可以添加-N来删除在屏幕上显示的行号) sd 带空格的Cat数据文件| sd '^\n' "行被认为是非空的 带空格的Cat数据文件| sd '^\s*\n' "行被认为是空的 Sd '^\s*\n' "数据文件就地编辑

您正在尝试的命令是正确的,只需使用-E标志。

sed -E '/^$/d'

-E标志使sed捕获扩展正则表达式。更多信息请点击这里

你可以说:

sed -n '/ / p' filename    #there is a space between '//'