linux中sed多行的示例分析

这篇文章将为大家详细讲解有关linux中sed多行的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

创新互联服务项目包括玉田网站建设、玉田网站制作、玉田网页制作以及玉田网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,玉田网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到玉田省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

在正常情况下,sed将待处理的行读入模式空间,脚本中的命令就一条接着一条的对该行进行处理,直到脚本执行完毕,然后该行被输出,模式空间请空;然后重复刚才的动作,文件中的新的一行被读入,直到文件处理完备。但是,各种各样的原因,比如用户希望在某个条件下脚本中的某个命令被执行,或者希望模式空间得到保留以便下一次的处理,都有可能使得sed在处理文件的时候不按照正常的流程来进行。这个时候,sed设置了一些高级命令来满足用户的要求。如果想要学习sed的高级命令,首先要了解如下两个缓存区:

1、模式空间(pattern space)的定义:模式空间就是一个缓存区,保存sed刚刚从输入端读取的。
2、暂存空间(hold space)的定义:暂存空间就是在处理模式空间数据的时候,临时缓存数据用的。

还有几个命令参数:

g: 将hold space中的内容拷贝到pattern space中,原来pattern space里的内容清除
G: 将hold space中的内容append到pattern space\n后
h: 将pattern space中的内容拷贝到hold space中,原来的hold space里的内容被清除
H: 将pattern space中的内容append到hold space\n后
x: 交换pattern space和hold space的内容

比如咱们想要倒排一个文件的内容,文件如下:

[qiu.li@l-tdata1.tkt.cn6 ~]$ cat tmp 
  1-line
  2-line
  3-line

执行如下命令:

[qiu.li@l-tdata1.tkt.cn6 ~]$ sed '2,$G;h;$!d' tmp
  3-line
  2-line
  1-line

下面咱们逐步理解上面的执行过程

一、让咱们来分析一下如下三条命令:

  • 2,$G:从第二行到最后一行执行G命令

  • h:执行h命令

  • $!d:删除除了最后一行的所有行

二、具体的操作

  1. 扫描到第一行

    1. 将1-line放入模式空间;此时模式空间还是1-line;

    2. 直接执行h命令,此时暂存空间是1-line;

    3. 执行d命令,删除了模式空间仅有的一行数据,删除之后,模式空间是空的

  2. 扫描到第二行

    1. 将2-line放入模式空间

    2. 执行G命令,将暂存空间的1-line添加到模式空间2-line的后面,此时模式空间是2-line\n1-line;

    3. 执行h命令,此时暂存空间的内容是2-line\n1-line;

    4. 执行d命令,模式空间被清空

  3. 扫描到第三行

    1. 将3-line放入模式空间,

    2. 执行G命令,将暂存空间的2-line\n1-line添加到模式空间3-line的后面,此时模式空间是3-line\n2-line\n1-line;

    3. 执行h命令,此时暂存空间的内容是3-line\n2-line\n1-line;

    4. 不执行$!d;

  4. 直接输出 3-line\n2-line\n1-line

 当然,命令:sed '1!G;h;$!d' tmp 也能有这个效果。

关于“linux中sed多行的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


当前名称:linux中sed多行的示例分析
URL分享:http://scyanting.com/article/ijjdid.html