1,1,1,n4s-1
1,3,4,n3s=
1,4,6,e4h=
1,5,8,e4h-1
1,6,2,e3ntx-2
1,7,5,n1s+2
1,8,7,n3s=
比如以上的数据格式以“,”为列分割符,现在我们想把每行的第三列数字都加8,怎么操作呢?
1、先在命令模式下,进行下面的替换
%s/([0-9]*,[0-9]*,)([0-9]*)/1sub(2)/g
数据变为如下形式:
1,1,sub(1),n4s-1
1,3,sub(4),n3s=
1,4,sub(6),e4h=
1,5,sub(8),e4h-1
1,6,sub(2),e3ntx-2
1,7,sub(5),n1s+2
1,8,sub(7),n3s=
2,再运行下面的命令
%s/sub(([0-9]*))/=submatch(1)+8/g
函数式
:s/替换字符串/=函数式
在函数式中可以使用 submatch(1)、submatch(2) 等来引用 1、2 等的内容,而submatch(0)可以引用匹配的整个内容。
函数式
:s/替换字符串/=函数式
在函数式中可以使用 submatch(1)、submatch(2) 等来引用 1、2 等的内容,而submatch(0)可以引用匹配的整个内容。