我有“我爱Suzi和Marry”,我想把“Suzi”改成“Sara”。
firstString="I love Suzi and Marry"
secondString="Sara"
预期的结果:
firstString="I love Sara and Marry"
我有“我爱Suzi和Marry”,我想把“Suzi”改成“Sara”。
firstString="I love Suzi and Marry"
secondString="Sara"
预期的结果:
firstString="I love Sara and Marry"
当前回答
这完全可以用bash字符串操作完成:
first="I love Suzy and Mary"
second="Sara"
first=${first/Suzy/$second}
这只会取代第一个事件;要将它们全部替换,请将第一个斜杠加倍:
first="Suzy, Suzy, Suzy"
second="Sara"
first=${first//Suzy/$second}
# first is now "Sara, Sara, Sara"
其他回答
模式,将第一次出现替换为特殊的包机:
${参数/模式/字符串}
将所有发生的情况替换为特殊特许状的模式:
${参数/ /模式/字符串}
firstString="I love //Suzi// and Marry"
secondString="Sara"
firstString="${firstString/\/\/Suzi\/\//"$secondString"}"
echo $firstString
上面印着:我爱莎拉和玛丽
这完全可以用bash字符串操作完成:
first="I love Suzy and Mary"
second="Sara"
first=${first/Suzy/$second}
这只会取代第一个事件;要将它们全部替换,请将第一个斜杠加倍:
first="Suzy, Suzy, Suzy"
second="Sara"
first=${first//Suzy/$second}
# first is now "Sara, Sara, Sara"
使用sed我们可以很容易地做到这一点
sed -i "s+$value_to_be_replaced+$with_variable1 "some character" $with_variable2+g" $file_name
echo [string] | sed "s|[original]|[target]|g"
“s”表示“替换” “g”表示“全局的,所有匹配的事件”
使用AWK:
firstString="I love Suzi and Marry"
echo "$firstString" | awk '{gsub("Suzi","Sara"); print}'