fed*_*qui 64
您可以使用以下任一方法执行此操作:
sed 's/.*six.*/fault/' file # check all lines
sed '/six/s/.*/fault/' file # matched lines -> then remove
Run Code Online (Sandbox Code Playgroud)
它获取包含six
并替换它的完整行fault
.
例:
$ cat file
six
asdf
one two six
one isix
boo
$ sed 's/.*six.*/fault/' file
fault
asdf
fault
fault
boo
Run Code Online (Sandbox Code Playgroud)
正是基于这一解决方案来替换使用含有桑达串整条生产线
更一般地说,您可以使用表达式sed '/match/s/.*/replacement/' file
.这将sed 's/match/replacement/'
在包含的那些行中执行表达式match
.在你的情况下,这将是:
sed '/six/s/.*/fault/' file
Run Code Online (Sandbox Code Playgroud)
如果我们有'一二二六一十一三四'并且我们想把'八'和'十一'作为我们的"坏"字怎么办?
在这种情况下,我们可以使用-e
for多个条件:
sed -e 's/.*six.*/fault/' -e 's/.*eight.*/fault/' file
Run Code Online (Sandbox Code Playgroud)
等等.
或者:
sed '/eight/s/.*/XXXXX/; /eleven/s/.*/XXXX/' file
Run Code Online (Sandbox Code Playgroud)
以上答案对我来说很好,只是提到了另一种方法
匹配单个模式并替换为新模式:
sed -i '/six/c fault' file
Run Code Online (Sandbox Code Playgroud)
匹配多个模式并替换为新模式(连接命令):
sed -i -e '/one/c fault' -e '/six/c fault' file
Run Code Online (Sandbox Code Playgroud)
将包含指定字符串的整行替换为该行的内容
文本文件:
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
Run Code Online (Sandbox Code Playgroud)
单串:
$ sed 's/.* display_name=\([[:alpha:]]\+\).*/\1/'
output:
100
101
Run Code Online (Sandbox Code Playgroud)
由空格分隔的多个字符串:
$ sed 's/.* display_name=\([[:alpha:]]\+\).* _id=\([[:digit:]]\+\).*/\1 \2/'
output:
Mozart 100
Bach 101
Run Code Online (Sandbox Code Playgroud)
调整正则表达式以满足您的需求
[:alpha] 和 [:digit:] 是字符类和括号表达式