Linux上文本处理三剑客sed

Sed是一种在线编辑器,行编辑器,一次处理一行内容,在处理时,把当前处理的行存储在临时缓冲区当中,该缓冲区称为“模式空间”,接着用sed命令处理缓冲区中的内容,处理完毕后,把缓冲区的内容送到标准输出:然后紧接着去处理下一行,重复完成相同的操作,直至文件末尾;sed处理的整个过程中,对象文件中的内容并没有发生改变,除非使用重定向来存储处理后的结果。sed主要用来自动编辑一个或多个文件,简化对文件的反复操作过程。

Sed所具有的功能有:数据的替换,删除,新增等,这里的数据可以是一些关键字,也可以是一些特定的行。可谓sed的功能是非常丰富的,那我们就来具体了解下sed的用法。

sed 命令

简介:
sed - stream editor for filtering and transforming text
格式:
sed [OPTION]... {script-only-if-no-other-script} [input-file]...
选项:
-n:不输出模式空间内容的自动打印
-e: 多点编辑
-f:/PATH/TO/SCRIPT_FILE: 从指定文件中读取编辑脚本
-r: 支持使用扩展正则表达式
-i: 原处编辑

script:('地址命令')
   地址定界:
       (1) 不给地址:对全文进行处理
      (2)单地址:
               #: 指定的行
               /pattern/:被此处模式所能够匹配到的每一行
       (3) 地址范围:
               #,#
               #,+#
               /pat1/,/pat2/
               #,/pat1/
       (4) ~:步进
               1~2 奇数行
               2~2 偶数行
               
编辑命令:
    d: 删除模式空间匹配的行
    p: 显示模式空间中的内容
    a \text:在行后面追加文本;支持使用\n实现多行追加
    i\text:在行前面插入文本;支持使用\n实现多行插入
    c \text:替换行为单行或多行文本
    w /path/to/somefile: 保存模式匹配的行至指定文件
    r /path/from/somefile:读取指定文件的文本至模式空间中匹配到的行后
    =: 为模式空间中的行打印行号
    !:模式空间中匹配行取反处理
    s///:查找替换,支持使用其它分隔符,s@@@,s###
         替换标记:
             g: 行内全局替换
             p: 显示替换成功的行
             w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中
示例:
sed‘2p’ /etc/passwd                    #显示文件"passwd"中的内容,并打印第二行,因此第二行多显示一次
sed –n ‘2p’ /etc/passwd                #仅显示第二行
sed –n ‘1,4p’ /etc/passwd              #仅显示第一到第四行
sed –n ‘/root/p’ /etc/passwd           #仅显示匹配到的字符串‘/root/’的行
sed –n ‘2,/root/p’ /etc/passwd=        #从第二行开始匹配字符串‘/root/’的行,并仅显示匹配到的行
sed -n ‘/^$/=’ file                    #仅显示空行行号并打印行号
sed –n –e ‘/^$/p’ –e ‘/^$/=’ file      #仅显示文件"file"中的空行,并打印行号
sed‘/root/a\superman’ /etc/passwd      #在匹配字符串‘/root/’的行后面追加内容"superman"
sed‘/root/i\superman’ /etc/passwd      #在匹配字符串‘/root/’的行前面追加内容"superman"
sed‘/root/c\superman’ /etc/passwd      #将匹配字符串‘/root/’替换成superman
sed‘/^$/d’ file                        #删除文件"file"中的空行
sed‘1,10d’ file                        #删除文件"file"中的1到10行
nl /etc/passwd| sed‘2,5d’              #显示文件"passwd"中的第2到第5行;(nl相当于cat -b)
nl /etc/passwd| sed‘2a tea’            #在文件"passwd"中的第2后面追加内容"tea"
sed 's/test/mytest/g' example          #将匹配到的字符串"test"替换成"mytest" (g:为全局替换)
sed –n‘s/root/&superman/p’ /etc/passwd #将匹配到的字符串"root"替换成"rootsuperman",并仅显示匹配到的行 (&:引用被替换的内容)
sed –n‘s/root/superman&/p’ /etc/passwd #将匹配到的字符串"root"替换成"supermanroot",并仅显示匹配到的行
sed  -e ‘s/dog/cat/’ -e ‘s/hi/lo/’ pets#将匹配到的字符串"dog"替换成"cat",将匹配到的字符串"hi"替换成"lo"
sed –i.bak ‘s/dog/cat/g’ pets          #将匹配到的字符串"dog"替换成"cat",并在替换之前将文件备份成pets.bak

sed 的高级编辑命令

h:把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g:从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x:把模式空间中的内容与保持空间中的内容进行互换
n:读取匹配到的行的下一行覆盖至模式空间
N:追加匹配到的行的下一行至模式空间
d:删除模式空间中的行
D:删除当前模式空间开端至\n的内容(不在传至标准输出),放弃之后的命令,但是对剩余模式空间重新执行sed
示例:
sed -n 'n;p' FILE       #显示偶数行
sed '1!G;h;$!d' FILE    #逆向显示文件内容
sed '$!N;$!D' FILE      #取出文件后两行;
sed '$!d' FILE          #取出文件最后一行;
sed 'G' FILE            #每行后面添加一行空白行
sed '/^$/d;G' FILE      #将空白行去重,仅显示一行
sed 'n;d' FILE          #显示奇数行;
sed -n '1!G;h;$p' FILE  #逆向显示文件中的每一行;

原创文章,作者:Aleen,如若转载,请注明出处:http://www.178linux.com/32111

(0)
AleenAleen
上一篇 2016-08-09 20:45
下一篇 2016-08-09 21:49

相关推荐

  • ssh 笔记

    ssh

    Linux干货 2018-01-08
  • 浅谈用户名和权限

        小编已经写了两篇博客了,却忘了自我介绍,咳咳咳(隆zhuang重qiang介zuo绍shi)一下:翠衣薄纱如花艳,柳眉凤眼俏佳人说的就是我!不扯了其实,小编拥有一个四口之家,那么小编今天就借家献佛给你们讲讲用户组和权限。     所属主(me):一般为文件的创建者,谁创建了该文件,就天然的成…

    Linux干货 2017-07-30
  • Docker 简介

    Docker在现有云计算虚拟化中是非常火的一个项目,那么他和虚拟化有什么不同呢 从上图来看,好像和我们之前说到的虚拟化并没有什么不同,但这里需要说明的是在各guest主机上,是没有操作系统的,他们共用Host主机上的内核空间,只对用户空间进行了隔离。 因此在这种环境下我们不把他称为虚拟化而称作容器。 此种方式的实现主要基于了linux内核自带的两项技术,分别…

    2017-03-19
  • N26-第十三周

    1、建立samba共享,共享目录为/data,要求:(描述完整的过程)  1)共享名为shared,工作组为magedu;  2)添加组develop,添加用户gentoo,centos和ubuntu,其中gentoo和centos以develop为附加组,ubuntu不属于develop组;密码均为用户名;  3)添加samb…

    Linux干货 2017-06-01
  • Linux基础知识之用户和组的配置文件解析

    实验环境:  Linux系统的版本为CentOS6.8_x86_64版本,以root用户远程用xshell连接,进行实验。 1.创建用户设置的配置文件:/etc/default/useradd        useradd 的配置文件如下图所示:        &nbs…

    Linux干货 2016-08-02
  • httpd服务——CentOS6

    Web Service 应用层:http,https 实现某类具体应用 传输层协议:TCP,UDP,SCTP IANA:          0-1023:从所周知的端口,永久的分配给固定应用使用,特权端口       &…

    Linux干货 2016-10-09