我正试着用sed做这个
sed -i.bak 's,[href="#">bebeco.fr],href="http://www.bebeco.fr,http://mm.eulerian.net/dynclick/bebeco/?eml-publisher=bebeco&eml-name=deme_faible&eemail={email}&eurl=https://www.bebeco.fr/?utm_source=ANIM&utm_medium=Targeting&utm_campaign=deme_faible&utm_term=CCCC_seg_men&utm_content=website">bebeco.fr,g' pour_test_demenagement-lien-faible.html正如您可以想象的那样,由于多个元字符,sed命令行正在窃听,而不是更改行。
我能做些什么来解决这个问题,而不是把一个\放在每个元字符之前?
您认为awk可以帮助您,而无需进行编程吗?
提亚
发布于 2015-02-24 10:01:36
我只会用不同的分隔符。好的老~呢?如图所示,数据不包含~
sed 's~SEARCH~REPLACE~'你认为awk不需要编程就能有所帮助吗?
)由于awk是一种编程语言,我认为不进行编程是不可能的。然而,我认为sed可以胜任这份工作。
发布于 2015-02-24 10:07:12
您的regex语法已被排除。[href="#">bebeco.fr]匹配一个字符,即h、r、e等。最重要的是,您有三个字段,sed只允许两个字段,所以不清楚您想要完成什么,但可能类似于
sed -i.bak 's,href="#">bebeco.fr,href="http://mm.eulerian.net/dynclick/bebeco/?eml-publisher=bebeco\&eml-name=deme_faible\&eemail={email}\&eurl=https://www.bebeco.fr/?utm_source=ANIM\&utm_medium=Targeting\&utm_campaign=deme_faible\&utm_term=CCCC_seg_men\&utm_content=website">bebeco.fr,g' pour_test_demenagement-lien-faible.html也就是说,用长URL替换href="#">bebeco.fr中双引号字符串中的散列。
发布于 2015-02-24 12:31:01
您可以尝试创建和转义模式。
MyStringSearch='ref="#">bebeco.fr'
MyStringSearchEsc="$( printf '%s' "${MyStringSearch}" | sed 's#\[]["\&*.\\/+?]#\\&#g' )"
MyStringReplace='href="http://mm.eulerian.net/dynclick/bebeco/?eml-publisher=bebeco\&eml-name=deme_faible\&eemail={email}\&eurl=https://www.bebeco.fr/?utm_source=ANIM\&utm_medium=Targeting\&utm_campaign=deme_faible\&utm_term=CCCC_seg_men\&utm_content=website">bebeco.fr'
MyStringReplaceEsc="$( printf '%s' "${MyStringReplace}" | sed 's#\[\\/\&"]#\\&#g' )"在我们面前,它的最终结果。
sed "s/${MyStringSearchEsc}/${MyStringReplaceEsc}/g" pour_test_demenagement-lien-faible.htmlhttps://stackoverflow.com/questions/28692690
复制相似问题