8月9日sed命令

sed命令及vim基础使用命令

处理文本的工具sed

stream editor,行编辑器

   sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。sed主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等。

sed工具:

sed [option]..'script' inputfile..

常用选项:

 -n:不输出模式空间内容的自动打印
 -e:多点编辑
 -f /PATH/TO/SCRIPT_FILE:从指定文件中读取编辑脚本
 -r:支持使用扩展正则表达式
 -i:原处编辑
script:
 '地址命令'
地址定界:
(1)不给地址:对全文进行处理
(2)单地址:
    #:指定的行
    /pattern/:被此处模式所能够匹配到的每一行
(3)地址范围:
    #,#
    #,+#
    /pat1/,/pat2/
    #,/pat1/
 (4)~:步进
    1~2 奇数行
    2~2 偶数行

编辑命令:

 d:删除模式空间匹配的行
 sed -n '1,3d' /tmp/fstab 
 p:显示模式空间中的内容
 a \text:在行后面追加文本;支持使用\n实现多行追加
 i \text:在行前面插入文本;支持使用\n实现多行插入
 c \text:替换行为单行或多行文本
 w /path/to/somefile:保存模式匹配的行至指定文件

 sed '/^UUID/w /tmp/fstab.sh /tmp/fstab'
 r /path/from/somefile:读取指定文件的文本至模式空间中匹配到的行后
 =:为模式空间中的行打印行号
  sed '/^UUID/=' /tmp/fstab
 !:模式空间匹配行取反处理
       地址定界!编辑命令;
  sed '/^#/!d' /tmp/fstab
s///:查找替换,支持使用其他分隔符,s@@@,s
 替换标记:
  g:行内全局替换
  p:显示替换成功的行
  w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中
sed示例:
 sed '2p' /etc/passwd    passwd下的内容都输出,其中第二行多输出一次
 sed -n '2p' /etc/passwd   只显示passwd中第二行的内容
 sed -n '1,4p' /etc/passwd  只显示passwd中1~4行的内容
 sed -n '/root/p' /etc/passwd 只显示带root的行
 sed -n '2,/root/p' /etc/passwd 显示第二行开始,到带root的行结束
 sed -n '/^$/=' file 显示空行的行号    
 sed -n -e '/^$/p -e' /'^$/=' f1 显示偶数行的行号
 sed '/root/a\superman' /etc/passwd 在root出现的行下加supperman
 sed '/root/i\superman' /etc/passwd 在root出现的行上加supperman
 sed 'root/c\superman' /etc/passwd root出现的行替换成superman

 sed '/^$/d' file 删除空白行
 sed '1,10d' file  删除1-10行
 nl /etc/passwd |sed '2,5d' 显示行号并删除2-5行(nl=cat)
 nl /etc/passwd |sed '2a\tea' 显示行号,在第二行下加tea
 sed 's/test/mytest/g' example
 sed -n 's/root/&superman/p' /etc/passwd 匹配root的行,第一个root后加superman,p是打印出来的意思
 sed -n 's/root/superman&/p' /etc/passwd  同上,superman加在root前
 sed -n 's/root/superman&/pg' /etc/passwd  加g的意思是全部的root前都加上superman 
 sed -e 's/dog/cat' -e 's/hi/lo' pets 文件下cat替换成dog,lo替换成hi
 sed -i.bak 's/dog/cat/g' pets

高级编辑命令:

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

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

    g:从保持空间取出数据覆盖至模式空间  

    G:从保持空间取出内容追加至模式空间

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

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

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

    d:删除模式空间中的行

     D:删除当前模式空间开端至\n的内容(不在传至标准输出),放弃之后的命令,但是对剩余模式空间重新执行sed

课堂及课后作业

1、删除/etc/grub2.cfg文件中所有以空白开头的行行首的空白字符

sed 's@^[[:space:]]\+@@' /etc/grub2.cfg

8月9日sed命令

2、删除/etc/fstab文件中所有以#开头,后面至少跟一个空白字符的行的行首的#和空白字符

sed 's@^#[[:space:]]\+@@g' /etc/fstab

8月9日sed命令

注释:用+时会出现#开头的行不会被替换掉,因为#后面没有空白符,所以删不掉#开头的后面没有空白符的行。用?时就能删除,?代表#后面空白符可有可无 8月9日sed命令

3、在/root/install.log每一行行首增加#号

sed -r 's@^@#@' /root/install.log

8月9日sed命令

注释:或sed -r 's@(.*)@#\1@' /root/install.log 后面的\1是引用前面一整行,再在一整行前面加#

4、在/etc/fstab文件中不以#开头的行的行首增加#号

sed -e 's@^@#&@' -e 's@##@#@' /etc/fstab

8月9日sed命令

或者sed 's@^[^#]@#&@' /etc/fstab

5、处理/etc/fstab路径,使用sed命令取出其目录名和基名

echo /etc/sysconfig/ |sed -r 's#/.*/([^/]+)/?#\1#g'
echo /etc/sysconfig/ |sed -r 's#(/.*/)[^/]+/?#\1#g'

8月9日sed命令

6、利用sed 取出ifconfig命令中本机的IPv4地址

ifconfig|sed -n 2p |sed -r 's/.*addr:(.*)  Bca.*/\1/'

\1取出前面括号内的内容 ifconfig |sed -n 2p |sed -e 's@inet@@' -e 's@net.*@@'

8月9日sed命令

7、统计centos安装光盘中Package目录下的所有rpm文件的以.分隔倒数第二个字段的重复次数

原创文章,作者:15152188070,如若转载,请注明出处:http://www.178linux.com/33007

(0)
1515218807015152188070
上一篇 2016-08-11
下一篇 2016-08-11

相关推荐

  • 第三周学习总结之简单文本处理

    写在最前 通过前面的学习,我们已经知道Linux是一个一切皆文件的系统,因此对文件的处理就显得尤为重要,到目前为止,对于新手来说可能连鼎鼎大名的三剑客也未必听过,不过在这之前我们也可以使用一些非常好用的文本处理工具来完成一些简单文件的处理。本次内容就是讲讲如何使用几个简单文本处理工具的组合完成一些实用的功能。 文本处理工具 文本处理工具,用我的理解就是能够对…

    2017-12-19
  • Mysql备份II

    Mysql备份II V.II.I单台或共用机器,数据量和访问量小50G< 1 Mysqldump(全导出,导库,导表) 锁表 如果这时有些入会锁住或者超时 2 至少停止写入 防止innodb配置还没刷到磁盘里 先flash tables /usr/local/mysql/bin/mysqladmin -S /tmp/mysql.so…

    Linux干货 2016-06-09
  • 第五天03条件判断与循环

           选择执行     选择执行:注意:if语句可嵌套                           单分支       &n…

    Linux干货 2016-08-18
  • rsyslog日志服务

    一、知识整理: 1、日志服务rsyslogd新特点:     多线程;     基于SSL/TLS/UDP/TCP/RELP网络协议传输日志信息;     强大的过滤器,实现过滤日志信息中任何部分的内容;   &nbsp…

    Linux干货 2016-10-24
  • N26-第四周作业

    一、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 思路:先用递归操作复制文件,再用chmod改变文件及其下目录权限。 方法一: [root@promote ~]# cp -r /etc/skel /home/tuser1 #复制文件并改名 [root@promote ~]#…

    2017-05-07
  • 用户,组和权限管理 基础命令整理

    安全3A任何一个安全策略都应该有Authentication(认证)、Authentication(授权)、Accouting|Audition(审计)这三个措施。 用户(User)Linux用户是安全3A中的Authentication(认证)措施。用户在登录时,系统会检查用户输入的用户名和密码。如果用户输入的用户名和密码匹配,会根据用户信息给用户分配一个…

    Linux干货 2017-03-16