sed

sed

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

用法:

sed [option]… ‘script’ inputfile…

  • 常用选项:

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

    • 地址定界:
      (1) 不给地址:对全文进行处理
      (2) 单地址:
      #: 指定的行
      /pattern/:被此处模式所能够匹配到的每一行
      (3) 地址范围:
      #,#
      #,+n : 从第#行开始,一直向下n行;
      /pat1/,/pat2/ :从第一次被/pat1/匹配到的行开始,到最后一次匹配到/pat2/的行结束;
      #,/pat1/ :从第#行开始,到第一次匹配到/pat1/的行结束;
      (4) first~step:指定起始行,以及步长
      1~2 奇数
      2~2 偶数行

    • 编辑命令:

      • d: 删除模式空间匹配的行
        p: 显示模式空间中的内容
        a [ \ ]text:在指定行后面追加文本(text),支持使用\n实现多行追加
        i [ \ ]text:在行前面插入文本,支持使用\n实现多行追加
        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

      奇数行

      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’

      只保留最后两行

      seq 10|sed ‘$!N;$!d’

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

(0)
ss
上一篇 2017-04-26
下一篇 2017-04-27

相关推荐

  • 初入linux_基础(一)

    初入Linux知识点总结(一) 一、理论知识 1、时间点: 1946年 第一代计算机ENIAC诞生于美国宾州大学,特点:块头大、效率低 数学家冯诺•依曼提出计算机体系结构组成部分:计算器、运算器、存储器、输入设备、输出设备 1969年 UNIX在美国贝尔实验室诞生 1984年 GNU项目和软件基金会成立 1991年 Linux在芬兰赫尔辛基诞生 2、计算机的…

    Linux干货 2017-02-18
  • ☞计算机网络{ 基础知识;网卡bonding;网关路由; }

      计算机网络{ 基础知识;网卡bonding;网关路由; }        网络是指“三网”,即电信网络、有线电视网络和计算机网络。计算机网络最早起源于美苏冷战时期ARPANET网络,如今已经发展成为Internet2和NGI等具有多层次结构的网络。不同作用范围的网络可分为:广域网WAN 、局域网LAN 、…

    Linux干货 2016-09-06
  • Centos 7 DNS配置及理论详解

    DNS是什么及BIND讲解内容 域名系统(英文:Domain Name System,缩写:DNS)是internet的一项服务。它作为将域名和IP地址相互映射服务,能够使人更方便地访问互联网。DNS使用TCP和UDP端口53。当前,对于每一级域名长度的限制是63个字符,域名总长度则不能超过253个字符。讲解内容:    DNS名称解析方…

    Linux干货 2016-04-25
  • 信息论的熵

    1.  前言    熵的概念最早起源于物理学,用于度量一个热力学系统的无序程度。    在信息论里则叫信息量,即熵是对不确定性的度量。从控制论的角度来看,应叫不确定性。信息论的创始人香农在其著作《通信的数学理论》中提出了建立在概率统计模型上的信息度量。他把信息定义为“用来消除不确定性的东西”。在信息世界,熵越…

    Linux干货 2016-03-27
  • 软件编译安装小结

    原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://nolinux.blog.51cto.com/4824967/1439073     本文主要针对 configure 和 cmake 做一个介绍以及我们重新配置编译参数文件时,都需要做哪些清…

    Linux干货 2016-08-15
  • Python 课堂笔记

    第二天

    Linux干货 2018-03-21