单独使用sed的解决方案
sed本身能够产生未修改的行和已修改的行:
$ echo "redis::staging::key" | sed 's/^/RENAME /; p; s/staging/development/g'RENAME redis::staging::keyRENAME redis::development::key
在上面,sed首先将RENAME字符串添加到该行的开头。然后,
p命令告诉sed打印当时的行(“ staging”仍在其中)。下一个替换项放入“
development”,然后也打印该版本。
更新: 假设我们要在一行上输出:
$ echo "redis::staging::key" | sed 's/.*/RENAME & &/; s/staging/development/2'RENAME redis::staging::key redis::development::key
s上面的第一个命令将RENAME添加到开头,然后将其加倍。第二个阶段用开发替换了第二个阶段的出现。
为什么xargs版本没有替换?
xargs -I {} echo "RENAME {} $(echo {} | sed 's/staging/development/g')"在执行xargs之前,bash处理字符串。特别是,它看到
$(echo {} | sed's/staging/development/g')并执行它(“命令替换”)并获得结果{}。因此,当xargs最终运行时,它会看到以下命令:xargs -I {} echo "RENAME {} {}"因此,
s/staging/development/g永远不会进行替换。
使xargs和shell以适当的顺序一起工作
有一个解决方法:
$ echo "redis::staging::key" | xargs -I {} sh -c 'echo RENAME {} $(echo {} | sed 's/staging/development/g')'RENAME redis::staging::key redis::development::key上面将bash命令放在单引号内,并将它们作为参数传递给
sh。这样,直到xargs进行替换后,外壳程序才处理字符串。



