加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

正则表达式 – 使用sed向后搜索和替换

发布时间:2020-12-14 02:28:49 所属栏目:百科 来源:网络整理
导读:如何在字符串中搜索特定单词/模式的最后一次出现并将其替换为另一个单词? 例如,搜索词是aaa,替换词是zzz 输入:aaa bbb ccc bbb aaa 期望的输出:aaa bbb ccc bbb zzz s / aaa / zzz /替换第一个单词.是否有其他选项可以反向搜索? 使用sed: x='aaa bbb cc
如何在字符串中搜索特定单词/模式的最后一次出现并将其替换为另一个单词?

例如,搜索词是aaa,替换词是zzz

输入:aaa bbb ccc bbb aaa

期望的输出:aaa bbb ccc bbb zzz

s / aaa / zzz /替换第一个单词.是否有其他选项可以反向搜索?

使用sed:
x='aaa bbb ccc bbb aaa'
sed 's/(.*)bbb/1zzz/' <<< "$x"

aaa bbb ccc zzz aaa

使用perl命令行:

sed不支持lookarounds所以如果你想给perl一个机会:

perl -pe 's/aaa(?!.*?aaa)/zzz/' <<< "$x"

aaa bbb ccc bbb zzz

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读