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

相关推荐

  • VIM入门及进阶

    什么是VIM?     VIM类似于Vi编辑器, 它是一个功能强大、可高度定制的文本编辑器, 是一个纯粹的自由软件。注意:vi和vim不完全相同 为什么要使用VIM?     相信大多数人接触Linux时使用的第一个文本编辑器都不是VIM,很多人看到VIM复杂的命令操作就望而祛步…

    系统运维 2016-03-04
  • 实验:配额、RAID、LVM

    实验:在centos7实现光盘yum源 1yum install autofs 2现在启动systemctl start autofs 3开机启动systemctl enable autofs 4 cat /etc/yum.repos.d/base.repo[centos7]name=centos7 repobaseurl=file:///misc/cdgp…

    Linux干货 2017-04-25
  • Nginx 代理和缓存

    一 实验环境 Nginx 版本:nginx-1.8.1 Nginx代理服务器WAN:192.168.1.5 LAN:172.16.2.1 Web1:172.16.2.2 Web2:172.16.2.3 1.  配置好IP、DNS 、网关,确保使用远程连接工具能够连接服务器 2.      …

    Linux干货 2016-12-05
  • 进程查看及管理

        在Linux系统中,触发任意一个事件时,系统都会将它定义为一个进程,并且给予这个进程一个ID,称为PID,同时依据触发这个进程与用户相关的属性关系,给予这个PID一组有效的权限设置。 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。…

    Linux干货 2016-11-27
  • 马哥教育网络班21期+第13周课程练习

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

    Linux干货 2016-10-17
  • mysql/mariadb基于ssl的主从复制

     当mysql/mariadb跨越互联网进行复制时别人可以窃取到mysql/mariadb的复制信息, 这些信息是明文的, 因此存在不安全性, 这里通过ssl对复制的信息进行加密      1. 创建证书中心 在主服务器上创建证书中心 cd /etc/pki/CA 生成私钥 (umask&…

    Linux干货 2016-12-05