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


当前回答

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

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

其他回答

您也可以使用此选项:

 grep -v 'pattern' filename

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

我在Mac上挣扎着。另外,我需要使用变量替换来完成。

所以我使用了:

sed-i“”/$pattern/d“$文件

其中$file是需要删除的文件,$pattern是要匹配删除的模式。

我从评论中选择了“”。

这里需要注意的是在“/$pattern/d”中使用双引号。当我们使用单引号时,变量不起作用。

此解决方案适用于对多个文件执行相同的操作。

for file in *.txt; do grep -v "Matching Text" $file > temp_file.txt; mv temp_file.txt $file; done

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

:g/<图案>/d

来源

从所有匹配的文件中删除行

grep -rl 'text_to_search' . | xargs sed -i '/text_to_search/d'