我想把文本"/>

sed ‘N,P,D,lable循环’高级应用综合实例

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sed ‘N,P,D,lable循环’高级应用综合实例相关的知识,希望对你有一定的参考价值。

   有一文本如下:

   技术分享

   我想把文本格式变成姓名加成绩格式,图示如下:

   技术分享

   自己捣鼓好久,用几条命令实现,具体如下:

   技术分享

   群里的大神,也写了条命令,如下:

   技术分享

   相当V5给力的一条sed命令。

   看得云里雾里的。刚好比较有得闲,仔细学习研究了2天时间,终于理解了。特意记录下理解过程,具体如下:

   命令:sed ‘:1;N;/\n[A-Za-z]/!s/\n/ /;t1;P;D‘

   具体解释:

   :1到t1,这是一个循环,用到的是 sed t lable,

   N,追加下一行进入匹配空间。

   /\n[A-Za-z]/!s/\n/ /,/\n[A-Za-z]/匹配任意一个\n(换行符)加英文字母。!不执行,s/\n/ /,删除换行符。这条命令整个的意思是,不匹配\n[A-Za-z]的行,删除\n(换行符)。

   P,打印多行匹配空间的第一行。

   D,删除多行匹配空间的第一行。

   N,P,D结合使用,建立一个输入输出循环,维护两行的匹配空间,只输出第一行,然后返回脚本的顶端,将所有命令用于匹配空间的第二行。请重点注意这点。NPD三个都写了就形成个循环,不能单独分析N或者P或者D。

   

   具体执行过程:

   先看文本:技术分享

   命令:sed ‘:1;N;/\n[A-Za-z]/!s/\n/ /;t1;P;D‘

   1.设立:1 label标识。

   2.读入文本第一行 am  

   3.执行N,读入下一行 99到匹配空间 现在匹配空间的内容为 am \n 99 

   4.执行匹配,不匹配,因此删除 \n,匹配空间为变为  am 99

   5.设置的结束循环的条件为:/\n[A-Za-z]/,暂时没有匹配到这个条件,执行t1,回到命令顶端1。

   6.读入下一行,依次执行上面的顺序。

   7.从am 到76,全部执行一遍,匹配空间的内容为 am 99 100 80 76

   8.读到yx这行的时候,匹配空间内容为 am 99 100 80 76 \n yx,注意:\nyx匹配/\n[A-Za-z]/,循环打破,执行P,D。

   9.重点:前面的N必须和P和D一起综合起来理解。输出匹配空间的第一行:am 99 100 80 76。匹配空间的第二行:yx,重新开始顺序执行命令。

   

本文出自 “gome学习” 博客,转载请与作者联系!

以上是关于sed ‘N,P,D,lable循环’高级应用综合实例的主要内容,如果未能解决你的问题,请参考以下文章

sed

"Sed" 高级实用功能汇总

sed高级命令

文本处理三剑客之 Sed ——高级编辑命令

sed命令n,N,d,D,p,P,h,H,g,G,x解析

sed命令n,N,d,D,p,P,h,H,g,G,x解析2