我有“我爱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"

其他回答

使用AWK:

firstString="I love Suzi and Marry"
echo "$firstString" | awk '{gsub("Suzi","Sara"); print}'

对于Dash,之前的所有帖子都不起作用

POSIX sh兼容的解决方案是:

result=$(echo "$firstString" | sed "s/Suzi/$secondString/")

这将替换每一行输入中的第一个出现的位置。添加/g标记替换所有出现的情况:

result=$(echo "$firstString" | sed "s/Suzi/$secondString/g")

试试这个:

ls *.ext | awk '{print "mv "$1" "$1".newext"}' | sed "s/.ext.newext/.newext/" | parallel {}

模式,将第一次出现替换为特殊的包机:

${参数/模式/字符串}

将所有发生的情况替换为特殊特许状的模式:

${参数/ /模式/字符串}

firstString="I love //Suzi// and Marry"
secondString="Sara"
firstString="${firstString/\/\/Suzi\/\//"$secondString"}"
echo $firstString

上面印着:我爱莎拉和玛丽

我认为这是你用例中最简洁的形式:

firstString="${firstString//Suzi/$secondString}"