Linux基础命令之sed用法

sed :流编辑器

    1.sedStream Editor   行处理工具,流编辑器 

对文件内容逐行进行处理调用操作并显示到STDOUT

        工作流程:

(1)sed默认不编辑原文件,而是逐行操作,复制一份到指定内存(pattern space,模式空间)

(2)pattern space内进行模式匹配,即和指定条件做匹配

不满足模式:输出到标准输出STDOUT

满足模式:进行指定的模式操作,再输出到STDOUT

(3)第二个特殊的内存空间   hold space:保持空间,临时保存操作在另一处内存

(4)当执行pattern space hold space相关选项时候回进行之间的数据流编辑操作

(5)最后根据操作执行hold space空间操作,选择性显示到STDOUT

wKioL1Z6rimBqRHCAADWjYF18LE279.jpg

2.格式:sed  [OPTION]…    {script-only-if-no-other-script}  [input-file]…

 其中{script-only-if-no-other-script}:指的是AddressCommands,地址界定执行命令

AddressCommands中间无空格,直接连接为一个选项操作

 ============ sed  [OPTION]…    AddressCommands    [input-file]…==============

        (1)OPTION常用选项

      -n:不输出模式空间中的内容至屏幕;

      -e script, --expression=script:多点编辑;

      -f  /PATH/TO/SED_SCRIPT_FILE   : 每行一个编辑命令;

     -r, --regexp-extended:支持使用扩展正则表达式;

     -i[SUFFIX], --in-place[=SUFFIX]:直接编辑原文件 ;

         (2)地址定界

      1)空地址:什么都不填写时,表示对全文进行处理

      2)单地址

     #:表示对指定的行

   /pattern/:被此模式所匹配到的每一行,其中模式两边的/不能省略

      3)地址范围  (#表示任意数字)

   #,#:从某行到某行,第二个#大于第一个#

   #,+#:从某行开始加多商行

   #,/pattern1/:从某行开始到第一次配到模式的行

   /pattern1/,/pattern2/:从第一次匹配到的模式1到第二次匹配到哦的模式2

      4)步进:~#~#   从第几行

   1~2:所有奇数行。从第一行开始,每次加两行读取

   2~2:所有偶数行。从第二行开始,每次加两行读取

        (3)编辑命令

d:删除;

p:显示模式空间中的内容;

a  \text:在行后面追加文本“text”,支持使用\n实现多行追加;

i  \text:在行前面插入文本“text”,支持使用\n实现多行插入;

c  \text:把匹配到的行替换为此处指定的文本“text”;

w /PATH/TO/SOMEFILE:保存模式空间匹配到的行至指定的文件中;

r  /PATH/FROM/SOMEFILE:读取指定文件的内容至当前文件被模式匹配到的行后面;文件合并;

=:为模式匹配到的行打印行号;

!:条件取反;

地址定界!编辑命令;

s///:查找替换,其分隔符可自行指定,常用的有s@@@, s###等;

替换标记:

g:全局替换;

w /PATH/TO/SOMEFILE:将替换成功的结果保存至指定文件中;

p:显示替换成功的行;

    练习1:删除/boot/grub/grub2.cfg文件中所有以空白字符开头的行的行首的所有空白字符;
	~]# sed  's@^[[:space:]]\+@@' /etc/grub2.cfg
    练习2:删除/etc/fstab文件中所有以#开头的行的行首的#号及#后面的所有空白字符;
	~]# sed  's@^#[[:space:]]*@@'  /etc/fstab
    练习3:输出一个绝对路径给sed命令,取出其目录,其行为类似于dirname;
	~]# echo "/var/log/messages/" | sed 's@[^/]\+/\?$@@'
	~]# echo "/var/log/messages" | sed -r 's@[^/]+/?$@@'

    3.pattern spacehold space编辑命令操作

         (1)常用选项

    h:把模式空间中的内容覆盖至保持空间中;

    H:把模式空间中的内容追加至保持空间中;

    g:把保持空间中的内容覆盖至模式空间中;

    G:把保持空间中的内容追加至模式空间中;

    x:把模式空间中的内容与保持空间中的内容互换;

    n:覆盖读取匹配到的行的下一行至模式空间中;

    N:追加读取匹配到的行的下一行至模式空间中;

    d:删除模式空间中的行;

    D:删除多行模式空间中的所有行;

         (2)实例演示

sed  -n  'n;p'  FILE:显示偶数行;

sed  '1!G;h;$!d'  FILE:逆序显示文件的内容;

sed  ’$!d'  FILE:取出最后一行;

sed  '$!N;$!D' FILE:取出文件后两行;

sed '/^$/d;G' FILE:删除原有的所有空白行,而后为所有的非空白行后添加一个空白行;

sed  'n;d'  FILE:显示奇数行;

sed 'G' FILE:在原有的每行后方添加一个空白行;



猜你喜欢

转载自blog.51cto.com/12686444/2331226