我如何使用sed来删除文本文件中包含特定字符串的所有行?
要删除该行并将输出结果打印到标准输出。
sed '/pattern to match/d' ./infile
直接修改文件--在BSD sed中不起作用。
sed -i '/pattern to match/d' ./infile
同理,但适用于BSD sed(Mac OS X和FreeBSD)--对GNU sed不起作用。
sed -i '' '/pattern to match/d' ./infile
直接修改文件(并创建一个备份)--在BSD和GNU sed中有效。
sed -i.bak '/pattern to match/d' ./infile
除了`sed'之外,还有许多其他方法可以删除带有特定字符串的行。
awk '!/pattern/' file > temp && mv temp file
ruby -i.bak -ne 'print if not /test/' file
perl -ni.bak -e "print unless /pattern/" file
while read -r line
do
[[ ! $line =~ pattern ]] && echo "$line"
done <file > o
mv o file
grep -v "pattern" file > temp && mv temp file
当然还有sed
(打印反义词比实际删除要快)。
sed -n '/pattern/!p' file
你可以用sed来替换文件中的原位行。然而,这似乎比使用grep进行反转到第二个文件,然后将第二个文件移到原文件上要慢得多。
例如
sed -i '/pattern/d' filename
或
grep -v "pattern" filename > filename2; mv filename2 filename
反正在我的机器上,第一个命令要花3倍的时间。