有一文本如下:

   wKioL1biZ-Sz1xc8AAATSnyE8Zg092.png

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

   wKioL1biaBvjxeIZAAANdo-YKZw002.png

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

   wKiom1biadGxZXkpAAAL8AqO1f0514.png

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

   wKioL1biarbzHQX9AAAEE30MzTo704.png

   相当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。

   

   具体执行过程:

   先看文本:wKiom1bic6iCAuxIAAADrB5RTs0843.png

   命令: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,重新开始顺序执行命令。