sed讲解与使用

        sed是一种流编辑器,它是文本处理中非常中的工具,能够完美的配合正则表达式使用,功能不同凡响。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用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:删除模式空间匹配的行
            p:显示模式空间中的内容
            a \text:在行后面追加文本;支持使用\n实现多行追加
            i\text:在行前面插入文本;支持使用\n实现多行插入
            c \text:替换行为单行或多行文本
            w /path/to/somefile:保存模式匹配的行至指定文件
            r /path/from/somefile:读取指定文件的文本至模式空间中匹配到的行后
            =:为模式空间中的行打印行号
            !:模式空间中匹配行取反处理 

        替换标记:

            s///:查找替换,支持使用其它分隔符,s@@@,s###
            g:行内全局替换
            p:显示替换成功的行
            w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中
sed示例
sed‘2p’ /etc/passwd

2p.jpg

sed –n ‘2p’ /etc/passwd

n2p.jpg

sed –n ‘1,4p’ /etc/passwd

1,4.jpg

sed –n ‘/root/p’ /etc/passwd

 root.jpg

sed–n ‘2,/root/p’ /etc/passwd从2行开始

2root.jpg

sed -n ‘/^$/p’ file 显示空行行号

空行.jpg

sed –n –e ‘/^$/p’ –e ‘/^$/p’ file

eee.jpg

sed‘/root/a\superman’ /etc/passwd行后

a.jpg

sed‘/root/i\superman’ /etc/passwd行前

i.jpg

sed‘/root/c\superman’ /etc/passwd代替行

c.jpg

sed‘/^$/d’ file

d.jpg

sed‘1,10d’ file

dd.jpg

nl/etc/passwd| sed‘2,5d’

ddd.jpg

nl/etc/passwd| sed‘2a tea’

2a.jpg

sed's/sync/mysync/g'

 sg.jpg

sed–n‘s/root/&superman/p’ /etc/passwd单词后

 &.jpg

sed–n‘s/root/superman&/p’ /etc/passwd单词前

2&.jpg

sed ‘s/var/cat/’ -e ‘s/sbin/lo/’ pets

 e.jpg

sed–i.bak ‘s/sbin/cat/g’ pets

bak.jpg

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

1.jpg

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

2.jpg

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

3.jpg

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

4.jpg

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

5.jpg

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

6.jpg

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

7.jpg

 

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

(1)
msj77539273msj77539273
上一篇 2016-08-15 14:31
下一篇 2016-08-15 14:31

相关推荐

  • 第5周作业

    1、显示当前系统上root、fedora或user1用户的默认shell     ~]# egrep "^(root|fedora|user1)" /etc/passwd 2、找出/etc/rc.d/init.d/functions文件中某单词后面跟一组小括号的行,如:hello();  …

    Linux干货 2017-01-07
  • vsftp通过pam_mysql做虚拟用户认证

    vsftpd可以通过三种账户登录系统: 系统账户:系统本地账户登录系统,默认进入的目录是用户家目录,可以在所有有权限的路径切换; 匿名账户:匿名用户登录,然后映射为一个本地用户; 虚拟账户:既不是系统本地用户也不是匿名用户,而是通过pam做第三方认证的方法,支持文件和数据库,ldap的认证,此处通过mysql进行实验; 一、准备实验环境 实验在一台虚拟机上进…

    Linux干货 2017-06-07
  • 八大排序算法

    概述 排序有内部排序和外部排序,内部排序是数据记录在内存中进行排序,而外部排序是因排序的数据很大,一次不能容纳全部的排序记录,在排序过程中需要访问外存。 我们这里说说八大排序就是内部排序。     当n较大,则应采用时间复杂度为O(nlog2n)的排序方法:快速排序、堆排序或归并排序序。    快速…

    Linux干货 2015-04-07
  • linux 简单命令

    前面介绍一些基本基础篇 后面主要介绍screen命令的用法。

    2017-11-19
  • 优云软件数据专家最佳实践:数据挖掘与运维分析

    这份研究报告,作者是优云软件数据专家陈是维,在耗时1年时间制作的一份最佳实践,今天和大家分享下,关于《数据采矿和运维分析》,共同探讨~ 数据挖掘(Data Mining)是从大量数据中提取或“挖掘”知识。 广义数据挖掘:数据挖掘是从存放在数据库、数据仓库或其它信息库中的大量数据挖掘有趣知识的过程。 数据挖掘技术侧重:1)概率与数理统计 2)数据库技术 3)人…

    大数据运维 2016-07-16
  • bash脚本编程实例

    bash脚本编程实例 1.写一个脚本 接受一个以上文件路径作为参数 显示每个文件拥有的行数 总结说明本次共为几个文件统计了其行数 #!/bin/bash # read -p “please input some paths:” paths if [ -z $paths ];then echo “There are not any paths inputtin…

    Linux干货 2017-08-14