有一文本如下:
我想把文本格式变成姓名加成绩格式,图示如下:
自己捣鼓好久,用几条命令实现,具体如下:
群里的大神,也写了条命令,如下:
相当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,重新开始顺序执行命令。