文本处理三剑客之一的sed

处理文本的工具sed

  • Stream EDitor, 行编辑器

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

  • 用法

    • sed[option]… ‘script’ inputfile…
  • 常用选项

    • -n:不输出模式空间内容到屏幕,即不自动打印
    • -e: 多点编辑
    • -f:/PATH/SCRIPT_FILE: 从指定文件中读取编辑脚本
    • -r: 支持使用扩展正则表达式
    • -i.bak: 备份文件并原处编辑
  • 地址定界

    • (1) 不给地址:对全文进行处理
    • (2) 单地址:

      • #: 指定的行
      • /pattern/:被此处模式所能够匹配到的每一行
    • (3) 地址范围:

      • #,#
      • #,+#
      • /pat1/,/pat2/
      • #,/pat1/
    • (4) ~:步进

      • 1~2 奇数行
      • 2~2 偶数行
  • 编辑命令

    • d: 删除模式空间匹配的行
    • p: 显示模式空间中的内容
    • a []text:在指定行后面追加文本,支持使用\n实现多行追加
    • i[]text:在行前面插入文本
    • c []text:替换行为单行或多行文本
    • w /path/somefile: 保存模式匹配的行至指定文件
    • r /path/somefile:读取指定文件的文本至模式空间中匹配到的行后
    • =: 为模式空间中的行打印行号
    • !:模式空间中匹配行取反处理
    • s///:查找替换,支持使用其它分隔符,s@@@,s###

      • 替换标记

        • g: 行内全局替换
        • p: 显示替换成功的行
        • w /PATH/TO/SOMEFILE:将替换成功的行保存至文件中
  • 高级编辑命令:

    • h: 把模式空间中的内容覆盖至保持空间中
    • H:把模式空间中的内容追加至保持空间中
    • g: 从保持空间取出数据覆盖至模式空间
    • G:从保持空间取出内容追加至模式空间
    • x: 把模式空间中的内容与保持空间中的内容进行互换
    • n: 读取匹配到的行的下一行覆盖至模式空间
    • N:读取匹配到的行的下一行追加至模式空间
    • d: 删除模式空间中的行
    • D:删除当前模式空间开端至\n的内容(不再传至标准输出),放弃之后的命令,但是对剩余模式空间重新执行sed

sed示例

  • 取奇数行

    • seq 10|sed -n ‘1~2p’
    • seq 10|sed ‘2~2d’
    • seq 10 |sed -n ‘2~2!p’
    • seq 10 |sed ‘n;d’
  • 取偶数行

    • seq 10 |sed -n ‘n;p’
  • 取IP

    • ifconfig eth0|sed -n 2p|sed -e ‘s/.r://’ -e ‘s/ B.//’
    • ifconfig eth0|sed -e ‘s/.inet addr://’ -e ‘s/ B.//’ -n -e 2p
    • ifconfig eth0|sed ‘2!d;s/^.r://;s/ .//’
  • 取基名

    • echo /etc/sysconfig/network-scripts/ |sed -r ‘s@(/.*/)([/]+/?)@\2@’
  • 取目录名

    • echo /etc/sysconfig/network-scripts/ |sed -r ‘s@(/.*/)([/]+/?)@\1@’
  • 对/etc/fstab非#开头的加注释

    • sed -r ‘s/([#])/#\1/’ /etc/fstab
    • sed -r ‘s/[#]/#&/’ /etc/fstab
  • 倒序显示

    • seq 10 |sed ‘1!G;h;$!d’

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

(0)
XIAJIDONGXIAJIDONG
上一篇 2017-04-27
下一篇 2017-04-27

相关推荐

  • Zabbix通过邮件报警

                    Zabbix通过邮件报警 前言 本篇文章转自我的个人博客 http://anyisalin.com 欢迎大家访问 这次的内容大部分都是操作, 但是大家需要对定…

    2016-05-13
  • Tomcat基础及常见使用入门

    Tomcat的简单介绍,安装,以及简单的配置运用

    2017-09-11
  • inotify介绍及rsync + inotify 实时同步备份

    1、前言 rsync (remote sync)是一款非常好的数据同步工具,能够通过对比同步双方的数据变动,实现增量同步,还可以通过LAN/WAN实现远程多台主机间文件的同步,还能结合crond任务计划来执行自动备份,又可以结合ssh实现远程数据备份的安全,种种特性使他看起来相当优秀。但如果需备份数据十分庞大时,它的不足之处就显现出来了,比如每次执…

    Linux干货 2016-06-15
  • 8.3_Linux文件系统权限和特殊权限浅析

    什么是Linux文件系统权限? 在Linux中的每一个文件或目录都包含有访问权限,这些访问权限决定了谁能访问和如何访问这些文件和目录。 Linux文件系统权限的分类 Linux中的权限分为:read(读)、write(写)、execut(执行)三种权限 文件和目录表示的权限也各有不同 权限对于文件的意义: r: 可使用文件查看类工具获取其内容 w: 可修改内…

    Linux干货 2016-08-05
  • init中的服务故障如何排除

    我们假设ypbind出故障 首先我们设 ypbind服务开机启动 chkconfig yubind on 然后查看服务 chkconfig –list    默认是2345启动   然后更改这个脚本,里面寄一个长期的休眠时间,模仿为错误 sleep 休眠时间 然后重新启动,看看系统如何报错。 然后系统等到要启动该服务的时候回一…

    2017-07-22
  • Hadoop HDFS分布式文件系统设计要点与架构

    Hadoop简介:一个分布式系统基础架构,由Apache基金会开发。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力高速运算和存储。Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS。HDFS有着高容错性的特点,并且设计用来部署在低廉的(low-cost)硬件…

    Linux干货 2015-04-13