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
下一篇 2016-08-09

相关推荐

  • Linux系统进程管理

    本章学习内容     ——进程概念     ——进程创建、切换和撤销     ——进程调度     ——进程分类     ——进程状态 &n…

    Linux干货 2016-09-13
  • ​Linux基础知识之磁盘及文件系统管理(一)

    1.设备类型:     块设备(block):随机访问,数据交换单位是"块"     字符设备(character):线性访问,数据交换的单位是"字符" 2.设备文件:FHS     /dev &nb…

    Linux干货 2016-08-29
  • 关于大型网站技术演进的思考(二):存储的瓶颈(2)

    原文出处: 夏天的森林   上篇里我讲到某些网站在高并发下会报出503错误,503错误的含义是指网站服务端暂时无法提供服务的含义,503还表达了网站服务端现在有问题但是以后可能会提供正常的服务,对http协议熟悉的人都知道,5开头的响应码表达了服务端出现了问题,在我们开发测试时候最为常见的是500错误,500代表的含义是服务端程…

    2015-03-11
  • 国际标准OSI七层模型和事实标准TCP/IP四层模型

    我们知道,标准分为三种:国际标准、国家标准和事实标准。那我们学习的两个重要模型:OSI和TCP/IP模型分别属于国际标准和事实标准,接下来我们来总结一下两种模型的分层及功能还有异同: 一:国际标准OSI模型 OSI:(Open System Interconnect) 开放系统互连,总共分为七层,从下到上顺序为:物理层(physical)、数据链路层(dat…

    2017-09-02
  • linux使用yum对程序包管理相关知识

     yum客户端:          配置文件:              /etc/yum.conf: 为所有仓库提供公共配置              /et…

    Linux干货 2017-01-02
  • 配置yum服务器——以centOS 6.9系统为例

    准备工作 关闭防火墙  关闭防火墙service iptables stop  设置防火墙开机不启动chkconfig iptables off  查看一下防火墙状态 iptables -vnL 如下图,可以看到已经关闭 关闭SElinux 使用命令 vim /etc/selinux/config 将SELINUX=enable…

    Linux干货 2017-08-05