sed之h;H和:a;N;ba使用

dn: identifier=1
objectClass: ZcValidRecord
DsId: 2
identifier:2955
subOptionName: Record
SvcId: 1
ZoneId: 0


dn: identifier=2
objectClass: ZcValidRecord
DsId: 2
identifier:2956
subOptionName: Record
SvcId: 2
ZoneId: 0


要求后面的数字替换前面的数字:
dn: identifier=2955
objectClass: ZcValidRecord
DsId: 2
identifier:2955
subOptionName: Record
SvcId: 1
ZoneId: 0


dn: identifier=2956
objectClass: ZcValidRecord
DsId: 2
identifier:2956
subOptionName: Record
SvcId: 2

ZoneId: 0

sed ':a;N;/\n$/!{$!ba};s/\([^0-9]*\)[0-9]*\(.*identifier:\)\([0-9]*\)/\1\3\2\3/' file
初一看这题觉得不难,就是简单的数字替换,关键就在于数字的位置,我们都知道不管是shell还是awk还是sed,它都是逐行执行的,换句话说,执行到后面的行后,就不可能再对前面的行进行修改,这个跟我们往常的前面匹配修改后面的内容不一样,这里我们利用sed,把内容统一读取后,用正则来匹配修改它。这里还有另外两个要点,第一,文本是以空行为段落分割,在N读取模式中匹配空行不能再是传统的 /^$/ ,而是 /\n$/ ,这点上特别注意,第二,针对空行触发条件,到了文件末尾时,没有空行来触发,所以要依据文件末行来触发替换,这里就有了两个标签跳转。
sed -n '1h;/^$/!{1!H;$!b};x;s/\([^0-9]*\)[0-9]*\(.*identifier:\)\([0-9]*\)/\1\3\2\3/p' file
这是 h;H 的搭配;道理也是一样把一个段落读入 hold space 里,再出发条件统一替换。


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值