bash – 在shell扩展中使用sed on xargs变量不起作用
我试图在Redis中进行批量密钥重命名,使用
shell为每个密钥名称替换一个替换. (似乎没有更好的方法在redis内部执行此操作).
redis-cli -n 5 KEYS "*::staging::*"| xargs -I {} echo "RENAME {} $(echo {} | sed 's/staging/development/g')" # Then pipe this command into redis-cli when working 我期待这样的输出: 相反,我得到这个: echo {} $(echo {} | sed’s / old / new /’)让我感到高兴…… 解决方法
单独使用sed的解决方案
sed本身能够生成未修改和修改的行: $echo "redis::staging::key" | sed 's/^/RENAME /; p; s/staging/development/g' RENAME redis::staging::key RENAME redis::development::key 在上面,sed首先将RENAME字符串添加到行的开头.然后,p命令告诉sed打印当时的行(“暂存”仍然在其中).下一个替换放入“开发”,然后也打印该版本. 更新:假设我们希望输出在一行: $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进行替换之前,shell不会处理该字符串. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |