设为首页 收藏本站
查看: 1214|回复: 0

[经验分享] Linux中sed的用法

[复制链接]

尚未签到

发表于 2019-2-18 08:49:08 | 显示全部楼层 |阅读模式
  1、sed   流编辑器,实现对文字的增删改替换查(过滤、取行),能同时处理多个文件多行的内容,可以不对原文件改动,把整个文件输入到屏幕,可以把只匹配到模式的内容输入到屏幕上。还可以对原文件改动,但是不会再屏幕上返回结果。
流程:Sed软件从文件或管道中读取一行,处理一行,输出一行;再读取一行,再处理一行,再输出一行……
模式空间:sed软件内部的一个临时缓存,用于存放读取到的内容。

  2、命令格式:sed  [选项]   [命令]   [输入文件]
  sed命令的常用选项:
-n :只打印模式匹配的行,一般与 p 一起使用。如:sed -n  ' 2p '  /data  表示输出/data的第二行,如:sed  -n '20,30p'    /data/boy显示 /data/boy的20到30行。
-e :进行多项编辑,即对输入行应用多条sed命令时使用,此为默认选项。如:sed -e '/^#/d'  -e '/^$/d'  /data/boy表示删除空格的行和#开头的行。


-f :将sed的动作写在一个脚本文件内,用–f filename 执行filename内的sed动作。
-r :支持扩展表达式
-i :直接修改文件内容,如:sed   -i   s#old#new#g   
常用基本命令:
d        :delete, 删除匹配到的行;
    p        :print,  显示匹配到的行;通常 p 会与参数 sed -n 一起用
    a \text:append, 在指定行后追加文本text,支持使用\n实现多行追加;
    i \text :insert, 在指定行前插入文本text,支持使用\n实现多行插入;
    c \text:将指定行的内容替换为文本text;
    w /file:write, 保存模式空间中匹配到的行至指定的文件中;
    r /file :read, 将指定文件的内容读取至当前模式空间中被匹配到的行后面,常用于实现文件合并;
                   sed  -i '/Ethernet/r myfile' test  匹配Ethernet的行,读进来另一个文件的内容,读进来的文件的内容会插入到匹配Ethernet的行后  
    s/pattern/replaces/:查找pattern用replaces替换;分隔符可自行指定,常用的分隔符有/, #, @等;
    替换标记:
            g:全局替换;
            w /file:将替换的结果保存至指定文件中;sed -i 's/pattern/replaces/w my.txt'  test    将替换后的结果保存到my.txt
            p:显示替换成功的行;
   
    y:用于(对应)转换字符;
    =:打印行号;
    ! :匹配后取反;
    l :打印行号,并显示控制字符;
    q:读取匹配到的行后退出;
           

3、sed在文件中查询文本的方式
x/p
查询第x行
sed -n '2p ' /data
x,y/p查询从x到y行sed -n '1,3p ' /data
/pattern/p查询包含pattern的行sed -n '/pattern/p' /data
/pattern 1/,/pattern 2/p查询包含pattern 1pattern 2的行sed -n '/pn1/,/pn2/p'  /data
/pattern/,xp查询从包含pattern的行到x行
sed -n '/pn/,5p'  /data
x,/pattern/p查询从x到包含pattern的行sed -n '5,/pn/p'  /data
x,y!p查询不包含指定行号x和y的行sed -n '5,8!p'  /data

  •         10{sed-commands}        对第10行操作
  •      10,20{sed-commands}     对10到20行操作,包括第10,20行
  •      10,+20{sed-commands}   对10到30(10+20)行操作,包括第10,30行
  •      1~2{sed-commands}       对1,3,5,7,……行操作
  •      10,${sed-commands}     对10到最后一行($代表最后一行)操作,包括第10行
  •        /oldboy/{sed-commands}         对匹配oldboy的行操作
  •        /oldboy/,/Alex/{sed-commands}  对匹配oldboy的行到匹配Alex的行操作
  •        /oldboy/,${sed-commands}       对匹配oldboy的行到最后一行操作
  •        /oldboy/,10{sed-commands}      对匹配oldboy的行到第10行操作,注意:如果前10行没有匹配到oldboy,sed软件会显示10行以后的匹配oldboy的行,如果有。
  •       1,/Alex/{sed-commands}         对第1行到匹配Alex的行操作
  •       /oldboy/,+2{sed-commands}      对匹配oldboy的行到其后的2行操作
  4、案例(sed 后不跟  -i  表示仅对输出改变,对源文件不改变

  •   单行增加到第2行后:   sed '2a 106,dandan,CSO' person.txt

  • 单行增加到第2行前:   sed '2i 106,dandan,CSO' person.txt
  • 多行增加到第2行前:   sed '2i 106,dandan,CSO\n107,bingbing,CCO' person.txt,每行之间加换行符    \n
  •   删除第二行:                   sed '2d' person.txt



  •   删除匹配oldboy或者Alex的行                  sed '/oldboy/,/Alex/d' person.txt
  •   用新行替代第2行                      sed '2c 106,dandan,CSO' person.txt



  • 分组替换\( \)和\1的使用说明
sed软件的\( \)的功能可以记住正则表达式的一部分,其中,\1为第一个记住的模式即第一个小括号中的匹配内容,\2第二记住的模式,即第二个小括号中的匹配内容,sed最多可以记住9个。

例:echo I am oldboy teacher.如果想保留这一行的单词oldboy,删除剩下的部分,使用圆括号标记想保留的部分。
echo I am oldboy teacher. |sed 's#^.*am \([a-z].*\) tea.*$#\1#g'
思路:用oldboy字符替换I am oldboy teacher.
下面解释用代替空格:
          ^.*am□ –>这句的意思是以任意字符开头到am□为止,匹配文件中的I am□字符串;
  
          \([a-z].*\)□–>这句的外壳就是括号\(\),里面的[a-z]表示匹配26个字母的任何一个,[a-z].*合起来就是匹配任意多个字符,本题来说就是匹配oldboy字符串,由于oldboy字符串是需要保留的,因此用括号括起来匹配,后面通过\1来取oldboy字符串。
          □tea.*$–>表示以空格tea起始,任意字符结尾,实际就是匹配oldboy字符串后,紧接着的字符串□teacher.;
  后面被替换的内容中的\1就是取前面的括号里的内容了,也就是我们要的oldboy字符串。
          ()是扩展正则表达式的元字符,sed软件默认识别基本正则表达式,想要使用扩展正则需要使用\转义,即\(\)。sed使用-r选项则可以识别扩展正则表达式,此时使用\(\)反而会出错。
  







运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-673766-1-1.html 上篇帖子: Linux awk用法 下篇帖子: Linux中date用法
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表