我有“我爱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"
当前回答
因为我不能添加评论。为了使示例更具可读性,可以这样写
full_string="I love Suzy and Mary"
search_string="Suzy"
replace_string="Sara"
my_string=${full_string/$search_string/$replace_string}
or
my_string=${full_string/Suzy/Sarah}
其他回答
对于Dash,之前的所有帖子都不起作用
POSIX sh兼容的解决方案是:
result=$(echo "$firstString" | sed "s/Suzi/$secondString/")
这将替换每一行输入中的第一个出现的位置。添加/g标记替换所有出现的情况:
result=$(echo "$firstString" | sed "s/Suzi/$secondString/g")
使用sed我们可以很容易地做到这一点
sed -i "s+$value_to_be_replaced+$with_variable1 "some character" $with_variable2+g" $file_name
因为我不能添加评论。为了使示例更具可读性,可以这样写
full_string="I love Suzy and Mary"
search_string="Suzy"
replace_string="Sara"
my_string=${full_string/$search_string/$replace_string}
or
my_string=${full_string/Suzy/Sarah}
如果明天你决定不再爱她,她也可以被取代:
today=$(</tmp/lovers.txt)
tomorrow="${today//Suzi/Sara}"
echo "${tomorrow//Marry/Jesica}" > /tmp/lovers.txt
离开爱人,一定有50种方法。
使用AWK:
firstString="I love Suzi and Marry"
echo "$firstString" | awk '{gsub("Suzi","Sara"); print}'