如何使用sed删除文本文件中包含特定字符串的所有行?


当前回答

要使用grep获得类似于就地的结果,可以执行以下操作:

echo "$(grep -v "pattern" filename)" >filename

其他回答

您也可以使用此选项:

 grep -v 'pattern' filename

这里,-v将只打印图案以外的图案(这意味着反转匹配)。

我发现大多数答案对我来说都没用,如果你使用vim,我发现这非常简单明了:

:g/<图案>/d

来源

echo-e“/thing_to_delete\ndd\033:x\n”|vim file_to_edit.txt

使用GNU sed的简单方法是:

sed --in-place '/some string here/d' yourfile

我用一个包含大约345000行的文件制作了一个小型基准测试。在这种情况下,使用grep的方法似乎比sed方法快15倍左右。

我已经尝试了使用和不使用设置LC_ALL=C,这似乎不会显著改变定时。搜索字符串(CDGA_00004.pdbqt.gz.tar)位于文件的中间位置。

以下是命令和计时:

time sed -i "/CDGA_00004.pdbqt.gz.tar/d" /tmp/input.txt

real    0m0.711s
user    0m0.179s
sys     0m0.530s

time perl -ni -e 'print unless /CDGA_00004.pdbqt.gz.tar/' /tmp/input.txt

real    0m0.105s
user    0m0.088s
sys     0m0.016s

time (grep -v CDGA_00004.pdbqt.gz.tar /tmp/input.txt > /tmp/input.tmp; mv /tmp/input.tmp /tmp/input.txt )

real    0m0.046s
user    0m0.014s
sys     0m0.019s