linux sed 命令

Posted on Posted in command
Tips: 本文创建于2015年12月3日,已超过 2 年,内容或图片可能已经失效!

语法规则 sed [option] 'command' input_file

option 选项

  1. -n 使用安静模式(想不通为什么不是-s)。在一般sed的用法中,所有来自stdin的内容一般都会被列出到屏幕上。但如果加上-n参数后,则只有经过sed特殊处理的那一行(或者动作)才会被列出来;  
  2. -e 直接在指令列模式上进行 sed 的动作编辑;  
  3. -f 直接将 sed 的动作写在一个文件内, -f filename 则可以执行filename内的sed命令;  
  4. -r 让sed命令支持扩展的正则表达式(默认是基础正则表达式);  
  5. -i 直接修改读取的文件内容,而不是由屏幕输出。  

常用的命令有以下几种:

  1. a \:追加行, a \的后面跟上字符串s(多行字符串可以用\n分隔),则会在当前选择的行的后面都加上字符串s;  
  2. c \:取代/替换行  
  3. c \:后面跟上字符串s(多行字符串可以用\n分隔),则会将当前选中的行替换成字符串s;  
  4. i \:插入行 i \后面跟上字符串s(多行字符串可以用\n分隔),则会在当前选中的行的前面都插入字符串s;  
  5. d:删除行,该命令会将当前选中的行删除;  
  6. p:打印,该命令会打印当前选择的行到屏幕上;  
  7. s:替换字符串,通常s命令的用法是这样的:1,2s/old/new/g,将old字符串替换成new字符串  

假设本地有一个文件

  1. root@ubuntu:~# cat test.txt   
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. happy everyday  
  8. end  

例子一:追加行 a追加

本例命令部分中的1表示第一行,同样的第二行写成2,第一行到第三行写成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中间所有的行(包含第二行和最后一行)。

  1. root@ubuntu:~# sed '1a \add one' test.txt  
  2. this is first line  
  3. add one  
  4. this is second line  
  5. this is third line  
  6. this is fourth line  
  7. this fifth line  
  8. happy everyday  
  9. end  

例子二

  1. root@ubuntu:~# sed '1,$a \add one' test.txt  
  2. this is first line  
  3. add one  
  4. this is second line  
  5. add one  
  6. this is third line  
  7. add one  
  8. this is fourth line  
  9. add one  
  10. this fifth line  
  11. add one  
  12. happy everyday  
  13. add one  
  14. end  
  15. add one  

例子三

  1. root@ubuntu:~# sed '/first/a \add one' test.txt  
  2. this is first line  
  3. add one  
  4. this is second line  
  5. this is third line  
  6. this is fourth line  
  7. this fifth line  
  8. happy everyday  
  9. end  

例子四

本例使用正则表达式匹配行,^ha.*day$表示以ha开头,以day结尾的行,则可以匹配到文件的"happy everyday"这样,所以在该行后面增加了"add one"字符串。

  1. root@ubuntu:~# sed '/^ha.*day$/a \add one' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. happy everyday  
  8. add one  
  9. end  

i命令(插入行)

i命令使用方法和a命令一样的,只不过是在匹配的行的前面插入字符串,所以直接将上面a命令的示例的a替换成i即可。

例子五 c替换

将最后一行替换成字符串"add one"

  1. root@ubuntu:~# sed '$c \add one' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. happy everyday  
  8. add one  

例子六

将第四行到最后一行的内容替换成字符串"add one"

  1. root@ubuntu:~# sed '4,$c \add one' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. add one  

例子七

将以ha开头,以day结尾的行替换成"replace line"

  1. root@ubuntu:~# sed '/^ha.*day$/c \replace line' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. replace line  
  8. end  

例子八 删除行

删除以ha开头,以day结尾的行

  1. root@ubuntu:~# sed '/^ha.*day$/d' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. end  

例子九

删除第四行到最后一行中的内容

  1. root@ubuntu:~# sed '4,$d' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  

例子十 打印行

  1. root@ubuntu:~# sed -n '4,$p' test.txt  
  2. this is fourth line  
  3. this fifth line  
  4. happy everyday  
  5. end  

例子十一

打印以ha开始,以day结尾的行

  1. root@ubuntu:~# sed -n '/^ha.*day$/p' test.txt  
  2. happy everyday  

例子十二 替换字符串

  1. root@ubuntu:~#  sed 's/line/text/g' test.txt  
  2. this is first text  
  3. this is second text  
  4. this is third text  
  5. this is fourth text  
  6. this fifth text  
  7. happy everyday  
  8. end  

例子十三

首先匹配以ha开始,以day结尾的行,本例中匹配到的行是"happy everyday"这样,然后再将该行中的happy替换成very happy

  1. root@ubuntu:~# sed '/^ha.*day$/s/happy/very happy/g' test.txt  
  2. this is first line  
  3. this is second line  
  4. this is third line  
  5. this is fourth line  
  6. this fifth line  
  7. very happy everyday  
  8. end  

例子十四

  1. root@ubuntu:~# sed 's/\(.*\)line$/\1/g' test.txt  
  2. this is first   
  3. this is second   
  4. this is third   
  5. this is fourth   
  6. this fifth   
  7. happy everyday  
  8. end  

这个例子有点复杂,先分解一下。首先s命令的模式是s/old/new/g这样的,所以本例的old部分即\(.*\)line$,sed命令中使用\(\)包裹的内容表示正则表达式的第n部分,序号从1开始计算,本例中只有一个\(\)所以\(.*\)表示正则表达式的第一部分,这部分匹配任意字符串,所以\(.*\)line$匹配的就是以line结尾的任何行。然后将匹配到的行替换成正则表达式的第一部分(本例中相当于删除line部分),使用\1表示匹配到的第一部分,同样\2表示第二部分,\3表示第三部分,可以依次这样引用。比如下面的

例子十五

  1. root@ubuntu:~# sed 's/\(.*\)is\(.*\)line/\1\2/g' test.txt  
  2. this  first   
  3. this  second   
  4. this  third   
  5. this  fourth   
  6. th fifth   
  7. happy everyday  
  8. end  

正则表达式中is两边的部分可以用\1和\2表示,该例子的作用其实就是删除中间部分的is。

» 转载请注明来源:呢喃 » linux sed 命令