用 sed 找到匹配时替换整行
Posted
技术标签:
【中文标题】用 sed 找到匹配时替换整行【英文标题】:Replace whole line when match found with sed 【发布时间】:2022-01-20 06:29:15 【问题描述】:如果匹配模式,我需要用sed
替换整行。
例如,如果该行是“一二六三四”并且如果存在“六”,则应将整行替换为“故障”。
【问题讨论】:
你考虑过grep -v
吗?
我意识到这已经有几年了,但如果它对你有用,你应该记得回来并支持/接受一个答案——而且看起来有一些似乎正确回答问题。
【参考方案1】:
将包含指定字符串的整行替换为该行的内容
文本文件:
Row: 0 last_time_contacted=0, display_name=Mozart, _id=100, phonebook_bucket_alt=2
Row: 1 last_time_contacted=0, display_name=Bach, _id=101, phonebook_bucket_alt=2
单个字符串:
$ sed 's/.* display_name=\([[:alpha:]]\+\).*/\1/'
output:
100
101
由空格分隔的多个字符串:
$ sed 's/.* display_name=\([[:alpha:]]\+\).* _id=\([[:digit:]]\+\).*/\1 \2/'
output:
Mozart 100
Bach 101
调整正则表达式以满足您的需求
[:alpha] 和 [:digit:] 是Character Classes and Bracket Expressions
【讨论】:
【参考方案2】:以上答案对我来说效果很好,只是提到了另一种方法
匹配单个模式并替换为新模式:
sed -i '/six/c fault' file
匹配多个模式并替换为新模式(连接命令):
sed -i -e '/one/c fault' -e '/six/c fault' file
【讨论】:
【参考方案3】:您可以使用以下任何一种方法:
sed 's/.*six.*/fault/' file # check all lines
sed '/six/s/.*/fault/' file # matched lines -> then remove
它获取包含six
的整行并将其替换为fault
。
例子:
$ cat file
six
asdf
one two six
one isix
boo
$ sed 's/.*six.*/fault/' file
fault
asdf
fault
fault
boo
它基于this solution 到Replace whole line containing a string using Sed
更一般地说,您可以使用表达式 sed '/match/s/.*/replacement/' file
。这将在包含match
的行中执行sed 's/match/replacement/'
表达式。在您的情况下,这将是:
sed '/six/s/.*/fault/' file
如果我们有“一二六八十一三四”并且我们想要 包括“八”和“十一”作为我们的“坏”词?
在这种情况下,我们可以将-e
用于多个条件:
sed -e 's/.*six.*/fault/' -e 's/.*eight.*/fault/' file
等等。
也可以:
sed '/eight/s/.*/XXXXX/; /eleven/s/.*/XXXX/' file
【讨论】:
如果我们有“一二六八十一三四”并且我们想将“八”和“十一”作为我们的“坏”词包括在内怎么办? s/.*six|eight|eleven.*/fault/g 会起作用吗? 如果我想将更改存储在同一个文件中怎么办? @M.M.H.Masud 只需使用sed -i
。你最好也使用sed -i.bak
,这样原始文件会被替换,但也会备份到file.bak
。
/g
标志在这里没用,因为一行只能有一个匹配项,而您只关心是否有一个或多个匹配项。
@tripleee 你是对的。某事 + .*
每行将有一个唯一的匹配,如果有的话。谢谢!【参考方案4】:
这可能对你有用(GNU sed):
sed -e '/six/c\fault' -e ';d' file
或:
sed '/six/c\fault'$'\n'';d' file
【讨论】:
以上是关于用 sed 找到匹配时替换整行的主要内容,如果未能解决你的问题,请参考以下文章