探索处理文本工具“sed”的相关奥妙

一:sed工具

1,set的介绍:sed是一种流编辑器,它一次处理一行内容。处理时,把当前 处理的行存储在临时缓冲区中,称为“模式空间”(pattern
space),接着用sed命令处理缓冲区中的内容,处理完成后
,把缓冲区的内容送往屏幕。然后读入下行,执行下一个循
环。如果没有使诸如‘D’的特殊命令,那会在两个循环之间
清空模式空间,但不会清空保留空间。这样不断重复,直到
文件末尾。文件内容并没有改变,除非你使用重定向存储输
出。 

它的功能:主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。

2,sed的用法:

sed -n 不输出模式空间内容到屏幕,既不自动打印
-e 多点编辑,对每行处理时,可以有多个script
-f 把script写到文件中,在执行sed时-f指定文件路径,如果是多个script,换行写

  -r 

支持正则表达式

-i 直接将处理的结果写入文件
-i 文件名 在将处理结果写入文件之前备份一份

script
地址的定界:

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

           sed -n ‘p’ 文件

(2)单地址:

           #:指定行

           sed -n ‘2p’ 文件: 指定文件的第二行内容

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

            sed -n ‘/nihao/p’ 文件:显示文件中匹配到带有nihao的一行

(3) 地址范围:

         #,#

       sed -n ‘1,5p’ 文件:显示文件中一到五行的信息

        #,#+

       sed -n ‘1,+2p’ 文件:显示文件中第一行和第三行的信息

      /part1/,/part2/

       sed -n ‘/n/,/m/’ 文件 :显示文件中第n到m行的信息

(4)~表示步进

sed -n ‘1~2p’ 只显示奇数行

sed -n ‘2~2p’ 只显示偶数行

编辑的命令:

d:删除模式空间匹配到的行,并立即启用下一轮循环

sed ‘2d’ 文件名 :删除文件中第二行的内容

p:打印当前模式空间内容,追加到默认输出之后 

a[\]txt :在指定行后面追加文本,可以使用\n实现多行追加

i[\]txt :在行前面插入文本

c[\]txt : 替换行为单位或多行文本

w /path/文件:保存模式匹配到的行至指定文件

r /path/文件 :读取指定文件的文本到模式空间中匹配到的行后

相关示例:

1、删除centos7系统/etc/grub2.cfg文件中所有以空白开头
的行行首的空白字符

探索处理文本工具“sed”的相关奥妙
2、删除/etc/fstab文件中所有以#开头,后面至少跟一个空
白字符的行的行首的#和空白字符

探索处理文本工具“sed”的相关奥妙
3、处理/etc/fstab路径,使用sed命令取出其目录名和基名

探索处理文本工具“sed”的相关奥妙

4、利用sed 取出ifconfig命令中本机的IPv4地址

探索处理文本工具“sed”的相关奥妙

5、统计centos安装光盘中Package目录下的所有rpm文件的以.分隔倒数第二个字段的重复次数

探索处理文本工具“sed”的相关奥妙

6、统计/etc/init.d/functions文件中每个单词的出现次数,并排序(用grep和sed两种方法分别实现)

探索处理文本工具“sed”的相关奥妙

第二种方法:
探索处理文本工具“sed”的相关奥妙

原创文章,作者:风之轨迹,如若转载,请注明出处:http://www.178linux.com/85418

(0)
风之轨迹风之轨迹
上一篇 2017-08-26
下一篇 2017-08-26

相关推荐

  • 网络基础

    计算机网络     计算机网络,是指将地理位置不同的具有独立功能的多台计算机及其外部设备,通过通信线路连接起来,在网络操作系统,网络管理软件及网络通信协议的管理和协调下,实现资源共享和信息传递的计算机系统。 1、网络通信设备     网络通信设备种类繁多,且日新月异,网络通信设备通常由网络线缆、网卡、集线器、中继器、网桥、交换机、路由器等组成。 网桥(Bri…

    Linux干货 2016-12-16
  • linux中更改文件权限的实验

      三种基本权限    r 读 数值表示为4 w写 数值表示为2 X 可执行数值表示为1              简单举例: -rw-rw-r–共十个字符,分成四段 第一个字符“-”表示普通文件;这个位置还可能会出现“l”链接;“d”表示目录 第…

    2017-07-15
  • N26-第四周-孙逸

    1、  复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 cp –r /etc/skel /home/tuser1 chmod –R 700 /home/tuser1 2、  编辑/etc/group文件,添加组hadoop。 group文件的内容格式: &…

    2017-03-10
  • SUID_SGID_Sticky简单总结

    参考: http://blog.chinaunix.net/uid-25314474-id-3313109.html —————————————权限——&#82…

    Linux干货 2015-09-14
  • linux挂载的基本使用

    挂载   挂载是指将一个设备(通常是存储设备)挂接到一个已存在的目录上。 我们要访问存储设备中的文件,必须将文件所在的分区(已有文件系统)挂载到一个已存在的目录上, 然后通过访问这个目录来访问存储设备。 挂载条件 1、挂载点必须是一个目录。 2、一个分区挂载在一个已存在的目录上,这个目录可以不为空,但挂载后这个目录下以前的内容将隐藏不可用。对于其他…

    Linux干货 2016-09-07
  • 第二十六天 iptables 初识

      Iptables是位于用户空间,是linux系统上的防火墙管理配置规则的工具,主要用于添加、删除、管理netfilter的规则,   Netfilter是位于内核中真正的防火墙,由5个钩子组成,也叫五个规则链。 Netfilter的作用:起到过滤封包,转换与映射IP地址和端口,拆分和修改封包内容,追踪封包等功能 Iptabl…

    Linux干货 2016-07-02