sed对比grep之理解

sed对比grep之理解

很多时候回车按下,没有结果,或是报错。 检查发现都是低级错误,关键是习惯刚学完grep,有写习惯没改过来。 sed语法很重要。script语法写对了,就成功了一大半,剩下的就是正则表达式的问题了。

sed与grep的区别是

grep是个行过滤器,筛选符合条件的行。也可以只显示每行匹配到的文本(-o选项),不对文本进行编辑,只是显示查找结果。 可以高亮显示查找结果。

sed是针对行的编辑器。根据地址界定(可是使用行号,正则表达式)对指定的进行编辑,编辑操作有删除,增加新行可多行,插入新行可多行。替换行 为单行或多行。 针对行内的内容修改只能是查找替换针对文本行进行编辑,编辑后使用p命令输出至标准输出。不能够高亮显示查找编辑结果。sed -i 原处编辑,改变文件内容,否则只是显示出来原文件无变化。

语法:

地址界定时使用的正则表达式的两边必须是/ 如 /patter/

script中的动作命令例如d和p。需要同时都要执行时,命令之间要加分号 ;

编辑命令:

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默认支持基本正则表达式,有时候写表达式的时候经常忘记加上“\”,建议用到正则表达式的话在sed的【options】中加上-r

script语法格式:

先地址界定COMMAND;COMMAND
必须指定要界定的地址,即想好要处理那些的行,再指定要做哪些动作(干什么)。命令之间必须分号隔开;

运行原理

sed是一个非交互式的流编辑器。所谓非交互式,是指使用sed只能在命令行下输入编辑命令来编辑文本,然后在屏幕上查看输出;而所谓流编辑器,是指sed每次只从文件(或输入)读入一行,然后对该行进行指定的处理,并将结果输出到屏幕(除非取消了屏幕输出又没有显式地使用打印命令),接着读入下一行。整个文件像流水一样被逐行处理然后逐行输出。

每次读取一个新行,执行一次script,循环执行直到最后一行。

sed显示特性

一次处读取一行,送到模式空间后没有被script匹配到的行默认显示 
    参数 -n 没有匹配到的行 不显示。

匹配到的且处理过的行  ‘script’中加入命令p 显示匹配到且处理过的行

经过命令处理的行(包括p),默认不输出,命令p是打印
w命令  w /path/to/somefile: 保存模式匹配的行至指定文件

查找替换的结果是默认显示的。无需p命令

关于查找替换

是只是每行第一次被查找到的内容被替换,要想全文替换,或目标行替换,就得在script中加g命令。从行首匹配替换到行尾

练习

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

    [root@yangyouwei ~]# sed 's@^[[:space:]]*@@' f5  
    abc
    bsdf
    
    
    ffsd
    f
    t

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

    [root@yangyouwei ~]# sed -n 's@^#[[:space:]]\+@@p' /etc/fstab
    /etc/fstab
    Created by anaconda on Wed Jul 20 16:58:24 2016
    Accessible filesystems, by reference, are maintained under '/dev/disk'
    See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info
    [root@yangyouwei ~]#

3、在/root/install.log每一行行首增加#号

    [root@yangyouwei ~]# sed -rn 's@(^.*$)@#\1@p' /etc/fstab
    [root@yangyouwei ~]# sed -n 's@^@#@p' /etc/fstab

4、在/etc/fstab文件中不以#开头的行的行首增加#号

    [root@yangyouwei ~]# sed -rn 's@^[^#]@#@p' /etc/fstab

5、处理/etc/fstab路径,使用sed命令取出其目录名和基名

    [root@yangyouwei ~]# echo /etc/fstab |sed -nr 's@[^/]+/?$@@p'
    /etc/

    [root@yangyouwei ~]# echo /etc/fstab |rev | sed -nr 's@/[^/]*/$@@p' |rev
    fstab

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

    [root@yangyouwei ~]# ifconfig | sed -nr '/Bcast/p' | sed -nr 's@[[:alpha:]:]*@@g;p' | sed -nr 's@^[[:space:]]+@@p' | sed -nr 's@[[:space:]]+.*$@@p'
    192.168.226.128

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

    [root@yangyouwei ~]# ls /media/cdrom/Packages/ | sed -nr 's@.[^.]*$@@p' | rev | cut -d. -f1 |sort | uniq -c
       2283 46_68x
          4 686i
        919 hcraon
          1 SNART

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

(0)
yywyyw
上一篇 2016-08-10
下一篇 2016-08-10

相关推荐

  • 正则表达式与扩展正则表达式

    基本正则表达式 字符匹配:.:匹配任意单个字符[]:匹配指定范围内的任意单个字符[^]:匹配指定范围外的任意单个字符[-]:匹配[]中指定范围内的任意一个字符,要写成递增POSIX字符类:[:digit:]:匹配任意一个数字字符[:lower:]:匹配小写字母[:upper:]:匹配大写字母[:alpha:]:匹配任意一个字母字符(包括大小写字母)[:aln…

    2017-09-10
  • 文件查找find与压缩

    1.locate:   locate是查询系统上预建的文件索引数据库    /var/lib/mlocate/mlocate.db   依赖于事先构建的索引   索引的构建是在系统较为空闲时自动进行(周期性任务),管理 员手动更新数据库(updatedb)    缺点:索引构建过…

    Linux干货 2016-08-18
  • redis-cli的一些有趣也很有用的功能

    redis-cli我们最常用的三个参数就是-h、-p、-a选项,分配用来指定连接的redis-server的host、port和登录密码。 通过redis-cli –help发现,redis-cli还提供了其他很多的参数和功能。 1)-x-x选项从标准输入(stdin)读取最后一个参数。 比如从管道中读取输入: echo -en “chen.qun” | r…

    Linux干货 2015-03-16
  • 非交互式添加分区

    非交互式添加分区 方法一 添加/deb/sdb 下的分区,其实位置为1到1000M,第二个分区位置为1001至3000M,位置千万不能指定错误 parted /dev/sdb mkpart primary 1 1000M parted /dev/sdb mkpart primary 1001 3000M 方法二 (1)将你要在parted命令行输入的命令实现…

    Linux干货 2017-04-24
  • Mysql之运用MHA的功能实现服务高可用

    MHA介绍 (Master High Availability) MHA(Master HA)是一款开源的 MySQL 的高可用程序,它为 MySQL 主从复制架构提供 了 automating master failover 功能。MHA 在监控到 master 节点故障时,会提升其中拥有最新数据的 slave 节点成为新的 master 节点,在此期间,…

    2017-09-14
  • Hadoop hdfs 分布式文件系统

    Hadoop简介:一个分布式系统基础架构,由Apache基金会开发。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力高速运算和存储。Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS。HDFS有着高容错性的特点,并且设计用来部署在低廉的(low-cost)硬件…

    Linux干货 2017-04-19