sed编辑器

sed: Stream EDitor, 行编辑器; 

用法:

sed [option]… ‘script’ inputfile…

script:

地址命令 

常用选项:

-n:不输出模式中的内容至屏幕;

-e: 多点编辑;

-f /PATH/TO/SCRIPT_FILE: 从指定文件中读取编辑脚本;

-r: 支持使用扩展正则表达式;

-i: 原处编辑;

例一:,删除文件已UUID开关的命令行

[root@localhost ~]# sed '/^UUID/d' /etc/fstab 

地址定界:

(1) 不给地址:对全文进行处理;

(2) 单地址:

#: 指定的行;

/pattern/:被此处模式所能够匹配到的每一行;

(3) 地址范围:

#,#

#,+#

/pat1/,/pat2/

#,/pat1/

(4) ~:步进

1~2

2~2

例一:指定第一行到第10行删除

[root@localhost ~]# sed '1,10d' /etc/fstab 

编辑命令:

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:将替换成功的结果保存至指定文件中;

例一:在UUID文本后追加文本

[root@localhost ~]# sed '/^UUID/a \hello dongzhikang' /etc/fstab

例二:将UUID命令替换结果保存到指定文件中

[root@localhost ~]# sed '/UUID/w /tmp/fstab.txt' /etc/fstab

例三:模式空间匹配到的行至指定文件中

[root@localhost ~]# sed '6r/etc/lssus' /etc/fstab

例四:显示符合条件的行号

[root@localhost ~]# sed '/^UUID/=' /etc/fstab
#
/dev/mapper/VolGroup-lv_root /                       ext4    defaults        1 1
10
UUID=d928b19c-a5b3-4b6d-918c-2952b6353c69 /boot                   ext4    defaults        1 2

例一:替换以p开关的c结尾的加er

[root@localhost etc]# sed 's@p..c@&er@' /etc/fstab 

练习1:删除/boot/grub/grub.conf文件中所有以空白开头的行行首的空白字符;

~]# sed ‘s@^[[:space:]]\+@@’ /etc/grub2.cfg 

练习2:删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符;

~]# sed ‘s@^#[[:space:]]\+@@’ /etc/fstab 

练习3echo一个绝对路径给sed命令,取出其基名;取出其目录名;

~]# echo “/etc/sysconfig/” | sed ‘s@[^/]\+/\?$@@’ 

高级编辑命令:

h: 把模式空间中的内容覆盖至保持空间中;

H:把模式空间中的内容追加至保持空间中;

g: 从保持空间取出数据覆盖至模式空间;

G:从保持空间取出内容追加至模式空间;

x: 把模式空间中的内容与保持空间中的内容进行互换;

n: 读取匹配到的行的下一行至模式空间;

N:追加匹配到的行的下一行至模式空间;

d: 删除模式空间中的行;

D:删除多行模式空间中的所有行; 

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: 逆向显示文件中的每一行;

例一:逆向显示文件中的每一行

[root@localhost ~]# sed '1!G;h;$p' test.txt

 

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

(0)
kangkang
上一篇 2015-07-06
下一篇 2015-07-08

相关推荐

  • linux运维

    linux运维大纲,学习路线图

    Linux干货 2017-10-21
  • varnish

    缓存 缓存之所以能够生效是程序的运行具有局部性特征: 时间局部性:一个数据被访问过之后,可能很快会被再次访问到; 空间局部性:一个数据被访问时,其周边的数据也有可能被访问到 缓存的是热区数据 时效性: 缓存空间耗尽:LRU,最近最少使用; 过期:缓存清理 缓存命中率:hit/(hit+miss) 页面命中率:基于页面数量进行衡量 字节命中率:基于页面的体积进…

    Linux干货 2017-07-03
  • 访问控制列表ACL

     ACL是Access Control List的缩写,主要的目的是提供传统的owner、group、others的read、write、execute权限之外的具体权限设置。ACL可以针对单一用户、单一文件、单一目录来进行r、w、x的权限设置,对于需要特殊权限的使用状况非常有帮助。使用getfacl和setfacl来设置查看acl的权限。ACL权…

    Linux干货 2016-08-07
  • linux上的LVM简明教程

    LVM是一个多才多艺的硬盘系统工具。在Linux上非常的好用,传统分区使用固定大小分区,重新调整大小十分麻烦。但是,LVM可以创建和管理“逻辑”卷,而不是直接使用物理硬盘。可以让管理员弹性的管理逻辑卷的扩大缩小,操作简单,而不损坏已存储的数据。可以随意将新的硬盘添加到LVM,以直接扩展已经存在的逻辑卷。 首先是实际的物理磁盘及其划分的分区和其上的物理卷(PV…

    Linux干货 2017-05-02
  • Linux Service and Security(Part 1)

    一、知识整理 1、不安全的传统协议: telnet、FTP、POP3等:不安全的密码; http、smtp、NFS等:不安全信息; Ldap、NIS、rsh等:不安全验证。 设计基本原则: 使用成熟的安全系统; 以小人之心度输入数据; 外部系统是不安全的; 最小授权; 减少外部接口; 缺省使用安全模式; 在入口处检查; 安全不是似是而非; 从管理上保护好系统…

    Linux干货 2016-10-09
  • 从Linux小白到大牛——与狼共舞的日子11

    马哥教育网络班21期+第10周课程练习 1、详细描述一次加密通讯的过程,结合图示最佳。 加密过程 1.使用单向加密算法,提取A的文件的特征码。 2.使用A的私钥对提取出来的特征码进行加密,把加密后的特征码附加在A的文件的后面。 3.使用对称加密对刚刚的A的文件和加密后的特征码进行加密,生成对称加密密钥 4.使用B的公钥对第3步骤的对称加密的密钥进行加密,加密…

    Linux干货 2016-12-05