在前面看到的都是单行模式。每次sed处理一个行。

但是sed是允许一次处理多行的。这就是所谓的多行模式空间。

多行模式空间命令有(N、D、P),他们分别对应单行模式空间(n、d、p)。

分别是他们的多行形式。只不过,d每次删除一行,而D每次删除多行模式空间中的“一行”,其实就是一个记录。

下面举例子。我们假设有一个文件,loves cc两个单词分散在不同的行。我们想通过sed将二者放在同一行。

  1. zoer@ubuntu:~$ cat data
  2. naughty loves
  3. cc,and cc loves naughty.
  4. they are very happy!
  5. zoer@ubuntu:~$ cat d
  6. N
  7. s/loves\ncc/loves cc\
  8. /
  9. zoer@ubuntu:~$ sed -f d data
  10. naughty loves cc
  11. ,and cc loves naughty.
  12. they are very happy!

例子中,使用N来创建多行模式空间,将loves\ncc直接替换成loves cc,然后在sed命令的末尾使用\来表示换行。则得到了上面的结果。

上面sed命令中的loves c\,反斜杠是换行之意。如果没有它,那么两行将成为一行。如下所示:

  1. zoer@ubuntu:~$ cat d
  2. N
  3. s/loves\ncc/loves cc\ /
  4. zoer@ubuntu:~$ sed -f d data
  5. naughty loves cc ,and cc loves naughty.
  6. they are very happy!

---------------------------------------------------------

注意,sed命令中,也是可以使用{}的。但是与awk中的{}是不同的。

sed中的{}用法:

/条件/{符合条件的组合命令}      请注意这里的“条件”,只有符合条件的才会进入后面的组合命令。

意思是说,对符合前面条件的行,执行后面的组合命令。命令中可以包含一条或者多条命令。

而awk中的{}则分为BEGIN、END等作用。【不过个人认为,awk中的{}也有一部分的功能是组合一组命令】

-----------------------------------------------------

多行删除

假设我们有一个文件中有很多空白行,现在需要把多个相邻的空白行只保留一个。怎么做?

如果仅仅使用sed的d命令,那么这么写:

  1. zoer@ubuntu:~$ cat d
  2. /^$/{
  3. N
  4. /^\n$/d
  5. }
  1. zoer@ubuntu:~$ cat data
  2. naughty loves
  3. cc,and cc loves naughty.
  4. they are very happy!
  5. here is any.
  6. and here.
  7. zoer@ubuntu:~$ sed -f d data
  8. naughty loves
  9. cc,and cc loves naughty.
  10. they are very happy!
  11. here is any.
  12. and here.

我们会发现,偶数行连在一起的,都被删除了。而奇数行连在一起的会留下一行。这是为什么?

解释一下上面使用d命令的sed脚本就明白了。

上面的 sed脚本中,

读取一行,如果是 空行,那么符合条件,由于使用了N,所以会接着读取下一行。

如果此行是空行,那么符合^\n$,sed会由于d命令而删除整个模式空间,所以两个空行都被删除了。【同理如果有四个空行,那么可以看做是两倍的两个空行】

如果此行不是空行,那么不符合^\n$,sed会输出之前的空行和当前的这个非空行。

这就是为什么使用d的时候,偶数个连在一起的空白行被全部删了。而奇数个的还留有一行空白。

----------------------

如果使用D,世界瞬间安静了。

  1. zoer@ubuntu:~$ cat data
  2. naughty loves
  3. cc,and cc loves naughty.
  4. they are very happy!
  5. here is any.
  6. and here.
  7. zoer@ubuntu:~$ sed -f d data
  8. naughty loves
  9. cc,and cc loves naughty.
  10. they are very happy!
  11. here is any.
  12. and here.

如果使用D,当读取到空行的时候,符合匹配的条件^$,然后会读取下一行,

1、如果不是空行,那么不匹配,输出之前的空行和刚刚读入的这个非空行。

2、如果是空行,那么匹配^\n$,此时删除上一个空行,将本次的空行作为输入继续运行这个脚本。显然,此时空行也是满足^$的,所以继续读取接下来的文件,重复1。

----------------------------------------------

多行打印

我们通过下面的例子来学习多行打印的P命令。

  1. zoer@ubuntu:~$ cat d
  2. /unix$/{
  3. N
  4. /\nsystem/{
  5. s// operating &/
  6. P
  7. D
  8. }
  9. }
  10. zoer@ubuntu:~$ cat data
  11. here are examples of the unix
  12. system. where unix
  13. system appears,it should be the unix
  14. operating system.
  15. zoer@ubuntu:~$ sed -f d data
  16. here are examples of the unix operating
  17. system. where unix operating
  18. system appears,it should be the unix
  19. operating system.

这里例子中,我们要匹配unix结尾的行,并且如果下一行是system,那么在unix之后加上operating。

注:在sed中,&意思是用正则表达式的内容替换掉读入的内容。另外,//之间不加任何内容,表示的是上一次的匹配。在这例子中就是\nsystem。

命令的执行过程如下:

首先读入一行。如果结尾匹配unix,那么读入下一行。

1、如果下一行以system开头,那么将system替换成 operating \nsystem,然后打印出来该替换之后的行并把原来的 行删除。

2、如果下一行不是system开头,那么以改行为输入,继续匹配是否以unix结尾。

转自:http://blog.csdn.net/imzoer/article/details/8740673

【转】SED多行模式空间的更多相关文章

  1. 【转】 SED多行模式空间

    1. sed执行模板=sed '模式{命令1;命令2}' 即逐行读入模式空间,执行命令,最后输出打印出来 2. 为方便下面,先说下p和P,p打印当前模式空间内容,追加到默认输出之后,P打印当前模式空间 ...

  2. 【shell】sed指定追加模式空间的次数

    最近遇到一个文本复制的场景,需要把文本的每一行都重复输出三次. 这个用awk或者sed实现都还是很简单的. sed代码: [root]$ seq | sed '{h;G;G}' 现在的问题是,如果每行 ...

  3. sed高级用法:模式空间(pattern space)和保持空间(hold space)

    摘自:https://blog.csdn.net/ITsenlin/article/details/21129405 sed高级用法:模式空间(pattern space)和保持空间(hold spa ...

  4. 借个例子说明sed的模式空间,以及针对模式空间的N,P,D用法

    下面是我们要处理的文本:题目要求是把所有散列在不同行的同一个中括号中的数据集中在一起, 见下表就秒懂了吧 处理前的文本 处理后的文本 [123456][ASDEF][ABCD123WF][789ADC ...

  5. 通过几个例子看sed的模式空间与保持空间

    SED之所以能以行为单位的编辑或修改文本,其原因在于它使用了两个空间:一个是活动的“模式空间(pattern space)”,另一个是起辅助作用的“暂存缓冲区(holdingspace)这2个空间的使 ...

  6. sed的模式空间和保持空间

    摘自:https://blog.csdn.net/wanglelelihuanhuan/article/details/51591809 sed的模式空间和保持空间 2016年06月06日 17:15 ...

  7. sed原理及sed命令格式 ,缓存区,模式空间

    4.1            Sed工作原理 sed是一个非交互式的流编辑器.所谓非交互式,是指使用sed只能在命令行下输入编辑命令来编辑文本,然后在屏幕上查看输出:而所谓流编辑器,是指sed每次只从 ...

  8. sed 模式空间 保持空间

    sed之所以能以行为单位的编辑或修改文本,其原因在于它使用了两个空间:一个是活动的"模式空间(pattern space)",另一个是起辅助作用的"保持空间(hold s ...

  9. sed 之 模式空间 & 保持空间

    模式空间:容纳当前输入行的缓冲区: 保持空间:作为辅助的一个缓冲区,可以和模式空间进行交互,但是命令不能直接作用于保持空间. 由上面定义可以知道,模式空间和保持空间是两个独立的缓冲区,可以进行交互,命 ...

随机推荐

  1. True 和 False

    True 和 False是Python中的关键字. 'True' 和 'False'是Python中的字符串. true 和 false 是Python中的变量名,需要提前定义.

  2. python的流程控制学习

    _username= 'haozheyu' _password= ' username = input("请输入用户:") password = input("请输入密码 ...

  3. 高可用高性能分布式文件系统FastDFS进阶keepalived+nginx对多tracker进行高可用热备

    在上一篇 分布式文件系统FastDFS如何做到高可用 中已经介绍了FastDFS的原理和怎么搭建一个简单的高可用的分布式文件系统及怎么访问. 高可用是实现了,但由于我们只设置了一个group,如果现在 ...

  4. Android基础_web通信2

    一.移动客服端实现对PC端数据的操作 在PC端模拟一个数据库,实现用户的增删改查,然后在移动客服端实现对PC端数据库的操作 在PC端建立三个表 用户表(Users),员工表(Emp), 部门表(Dep ...

  5. js面向对象学习笔记(三):原型

    //原型:改写对象下面公用的方法或者属性,让公用的方法或者属性在内存中只存在一份(提高性能)//原型:prototype :要写在构造函数的下面var arr =[1,2,3,4,5];var arr ...

  6. Codeforces Beta Round #1 A,B,C

    A. Theatre Square time limit per test:1 second memory limit per test:256 megabytes input:standard in ...

  7. 关于int *a[常量]与int (*a)[常量]的分析与区分(详解)

    前言: 小伙伴私信我说,int *a[常量]与int (*a)[常量]这个区分不开,C指针,确实是C中最难的部分,也是学C++,JAVA,包括你以后上岗用的非常频繁的东西,在这里我就简单论述一下吧,具 ...

  8. c语言基础学习07_关于指针的复习

    ============================================================================= 指针变量之间赋值是需要兼容的. 例如:int ...

  9. castle之动态代理

    动态代理 DynamicProxy,这里说的动态代理是直接使用Castle.net 中提供的,并非自己实现的,因为别人写的很好,拿着用就行了. 动态代理的工作模式: 一般我们获取一个类型的实例都是通过 ...

  10. 【程序员的吃鸡大法】利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏

    [先上一张效果图]: 一.原理: 其实原理很简单: 1.手机投屏到电脑: 2.截取投屏画面的题目部分,进行识别,得到题目和三个答案: 3.将答案按照一定的算法,进行搜索,得出推荐答案: 4.添加了一些 ...