Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2790895
  • 博文数量: 471
  • 博客积分: 7081
  • 博客等级: 少将
  • 技术积分: 5369
  • 用 户 组: 普通用户
  • 注册时间: 2012-01-04 21:55
文章分类

全部博文(471)

文章存档

2014年(90)

2013年(69)

2012年(312)

分类: LINUX

2013-05-06 09:04:35

 sed为流编辑器,流编辑器能够对管道中标准输入接收的数据进行编辑,而无需将要编辑的数据存储在磁盘上,它是基于行的,其按顺序对每一行执行命令,然后将结果写入到标准输出,它不修改任何输入文件。sed必须通过行号和正则表达式指定要改变的文本行。
sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。养成用单引号来括起sed命令是个好习惯。


点击(此处)折叠或打开


  1. [root@www ~]# sed [-nefr] [动作]
  2. 选项与参数:
  3. -n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
  4. -e :直接在命令列模式上进行 sed 的动作编辑,允许在同一行里执行多条命令;
  5. -f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
  6. -r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
  7. -i :直接修改读取的文件内容,而不是输出到终端。


  8. 动作说明: [n1[,n2]]function
  9. n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为]

  10. function:
  11. a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)
  12. c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
  13. d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
  14. i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行)
  15. p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
  16. s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!


点击(此处)折叠或打开

  1. ===================================增加=======================================
  2. 那如果是要在第二行前 i
  3. [root@localhost sed]# cat passwd.bak| sed '2i befort line2 insert'
  4.      1 root:x:0:0:root:/root:/bin/bash
  5. befort line2 insert
  6.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  7.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

  8. 在第二行后(亦即是加在第三行)加上a
  9. [root@localhost sed]# cat passwd.bak| sed '2a after line2 add'
  10.      1 root:x:0:0:root:/root:/bin/bash
  11.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  12. after line2 add
  13.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

  14. ===================================删除===================================
  15. 删除第1到38行 d
  16. [root@localhost sed]# sed -e '1,38d' ./passwd.bak
  17.     39 king:x:501:501::/home/king:/bin/bash
  18.     40 mysql:x:100:103:MySQL server:/var/lib/mysql:/bin/bash
  19. 删除第4到最后一行
  20. [root@localhost sed]# sed -e '4,$d' ./passwd.bak
  21.      1 root:x:0:0:root:/root:/bin/bash
  22.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  23.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

  24. ==================================修改===================================
  25. 以行为单位的替换与显示c
  26. [root@localhost sed]# sed '1,2c be placed part' ./passwd.bak
  27. be placed part
  28.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
  29.      4 adm:x:3:4:adm:/var/adm:/sbin/nologin

  30. 仅列出 /etc/passwd 文件内的第 1-4 行
  31. [root@localhost sed]# sed -n '1,4p' ./passwd.bak
  32.      1 root:x:0:0:root:/root:/bin/bash
  33.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  34.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
  35.      4 adm:x:3:4:adm:/var/adm:/sbin/nologin


  36. ==================================搜索+动作===================================
  37. 1、    数据的搜索并显示
  38. 搜索有root关键字的行’/ /p’
  39. [root@localhost sed]# sed '/root/p' ./passwd.bak
  40.      1 root:x:0:0:root:/root:/bin/bash
  41.      1 root:x:0:0:root:/root:/bin/bash
  42.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  43.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
  44.      4 adm:x:3:4:adm:/var/adm:/sbin/nologin
  45.      5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  46.      6 sync:x:5:0:sync:/sbin:/bin/sync
  47.      7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
  48.      8 halt:x:7:0:halt:/sbin:/sbin/halt
  49.      9 mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
  50.     10 news:x:9:13:news:/etc/news:
  51.     11 uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
  52.     12 operator:x:11:0:operator:/root:/sbin/nologin
  53.     12 operator:x:11:0:operator:/root:/sbin/nologin
  54. 如果root找到,除了输出所有行,还会输出匹配行。

  55. 使用-n的时候将只打印包含模板的行。
  56. [root@localhost sed]# sed -n '/root/p' ./passwd.bak
  57.      1 root:x:0:0:root:/root:/bin/bash
  58. 12 operator:x:11:0:operator:/root:/sbin/nologin
  59. 2、数据的搜寻并删除’/ /d’
  60. ./passwd所有包含root的行,其他行输出
  61. [root@localhost sed]# sed '/root/d' ./passwd.bak
  62.      2 bin:x:1:1:bin:/bin:/sbin/nologin
  63.      3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
  64.      4 adm:x:3:4:adm:/var/adm:/sbin/nologin
  65.      5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
  66.      6 sync:x:5:0:sync:/sbin:/bin/sync
  67.      7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
  68.      8 halt:x:7:0:halt:/sbin:/sbin/halt
  69.      9 mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
  70.     10 news:x:9:13:news:/etc/news:
  71.     11 uucp:x:10:14:uucp:/var/spool/uucp:/sbin/nologin
  72.     13 games:x:12:100:games:/usr/games:/sbin/nologin

  73. 3、数据的搜寻并替换sed 's/要被取代的字串/新的字串/g' g是表示全局替换
  74. 除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。

  75. 把所有的inet 换为king
  76. [root@localhost sed]# sed 's/inet/king/g' ./ifc.bak
  77. eth0 Link encap:Ethernet HWaddr 00:0C:29:FB:51:53
  78.           king addr:192.168.175.129 Bcast:192.168.175.255 Mask:255.255.255.0
  79.           king6 addr: fe80::20c:29ff:fefb:5153/64 Scope:Link
  80.           UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
  81.           RX packets:11869 errors:0 dropped:0 overruns:0 frame:0
  82.           TX packets:6886 errors:0 dropped:0 overruns:0 carrier:0
  83.           collisions:0 txqueuelen:1000
  84.           RX bytes:12307691 (11.7 MiB) TX bytes:644568 (629.4 KiB)
  85.           Interrupt:67 Base address:0x2024
  86. 每一行后面加上一个king,最后一行是空行,直接加在前面了
  87. Ps:正则表达式用在不同的地方代表不同的意思,
  88. sed '$d' filename $在此是一个定位符,代表文件的最后一行
  89. sed 's/$/hour/' filename $在此匹配行的最后一个字符
  90. [root@localhost sed]# sed 's/$/king/g' ./ifc.bak
  91. eth0 Link encap:Ethernet HWaddr 00:0C:29:FB:51:53 king
  92.           inet addr:192.168.175.129 Bcast:192.168.175.255 Mask:255.255.255.0king
  93.           inet6 addr: fe80::20c:29ff:fefb:5153/64 Scope:Linkking
  94.           UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1king
  95.           RX packets:11869 errors:0 dropped:0 overruns:0 frame:0king
  96.           TX packets:6886 errors:0 dropped:0 overruns:0 carrier:0king
  97.           collisions:0 txqueuelen:1000 king
  98.           RX bytes:12307691 (11.7 MiB) TX bytes:644568 (629.4 KiB)king
  99.           Interrupt:67 Base address:0x2024 king
  100. King
  101.     
  102. 每一行行首加上一个king,最后一行是空行,直接加在前面了
  103. [root@localhost sed]# sed 's/^/king/g' ./ifc.bak
  104. kingeth0 Link encap:Ethernet HWaddr 00:0C:29:FB:51:53
  105. king inet addr:192.168.175.129 Bcast:192.168.175.255 Mask:255.255.255.0
  106. king inet6 addr: fe80::20c:29ff:fefb:5153/64 Scope:Link
  107. king UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
  108. king RX packets:11869 errors:0 dropped:0 overruns:0 frame:0
  109. king TX packets:6886 errors:0 dropped:0 overruns:0 carrier:0
  110. king collisions:0 txqueuelen:1000
  111. king RX bytes:12307691 (11.7 MiB) TX bytes:644568 (629.4 KiB)
  112. king Interrupt:67 Base address:0x2024
  113. king

  114. 数据的搜寻并执行命令
  115. 找到匹配模式eastern的行后,
  116. 搜索/etc/passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把bash替换为blueshell,再输出这行:
  117. [root@localhost sed]# sed -n '/root/{s/bash/blueshell/;p}' ./passwd.bak
  118.      1 root:x:0:0:root:/root:/bin/blueshell
  119.     12 operator:x:11:0:operator:/root:/sbin/nologin


阅读(1046) | 评论(0) | 转发(0) |
0

上一篇:概念简答题

下一篇:nl显示行号

给主人留下些什么吧!~~