如何使用sed搜索和替换整个单词?
干
sed -i 's/[oldtext]/[newtext]/g' <file>
也将取代我不希望它做的[oldtext]
的部分比赛。
正则表达式中的\ b匹配单词边界(即第一个单词字符和非单词字符之间的位置):
$ echo "bar embarassment" | sed "s/\bbar\b/no bar/g"
no bar embarassment
在Mac OS X上,这些正则表达式语法都不能在sed中用于匹配整个单词
\bmyWord\b
\<myWord\>
现在听我说,相信我,这个丑陋的语法是你需要使用的:
/[[:<:]]myWord[[:>:]]/
因此,例如,仅用整个单词替换薄荷:
sed "s/[[:<:]]mint[[:>:]]/minty/g"
资料来源:re_format man page
使用\b
作为单词边界:
sed -i 's/\boldtext\b/newtext/g' <file>
在我的一台机器中,用“\b
”(没有引号)分隔单词不起作用。解决方案是使用“\<
”来开始分隔符,使用“\>
”来结束分隔符。
用Joakim Lundberg的例子来解释:
$ echo "bar embarassment" | sed "s/\<bar\>/no bar/g"
no bar embarassment
在shell命令中:
echo "bar embarassment" | sed "s/\bbar\b/no bar/g"
要么:
echo "bar embarassment" | sed "s/\<bar\>/no bar/g"
但如果你在vim,你只能使用后者:
:% s/\<old\>/new/g
$ echo "bar embarassment"|awk '{for(o=1;o<=NF;o++)if($o=="bar")$o="no bar"}1'
no bar embarassment