格式:

  sed [OPTION]... {script-only-if-no-other-script} [input-file]...

  sed [OPTION]... ‘地址定界+[高级]编辑命令’  file

常用选择:

  i    :修改内容

  i.bak  :先备份,然后再修改内容

  r    :支持正则表达式

  e    :支持多点编辑

  n    :不输出模式空间内容到屏幕,即不自动打印

'地址定界+[高级]编辑命令'

  地址定界

     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:读取指定文件的文本至模式空间中匹配到的行后

    =:为模式空间中的行打印行号 !:模式空间中匹配行取反处理

  高级编辑命令 P:打印模式空间开端至\n内容,并追加到默认输出之前

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

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

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

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

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

    d:删除模式空间中的行

    D:如果模式空间包含换行符,则删除知道第一个换行符的模式空间中的文本, 并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间不包含换行符,则会像发 出d命令那样启动正常的新循环

基本正则模式匹配

    匹配字符:

      . :任意一个字符。

      [abc] :表示匹配一个字符

      [a-Z] :表示匹配一个字符

      [^123] :匹配一个字符,这个字符是除了1、2、3以外的所有字符。

      对于一些常用的字符集,系统做了定义:

      [a-Z] 等价于 [[:alpha:]]

      [0-9] 等价于 [[:digit:]]

      [a-Z0-9] 等价于 [[:alnum:]]

      tab,space 等空白字符 [[:space:]]

      [A-Z] 等价于 [[:upper:]]

      [a-z] 等价于 [[:lower:]]

      标点符号 [[:punct:]]

    匹配次数:

      \{m,n\} :匹配其前面出现的字符至少m次,至多n次。
      \? :匹配其前面出现的内容0次或1次,等价于\{0,1\}。
      * :匹配其前面出现的内容任意次,等价于\{0,\},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。

    位置锚定:

      ^ :锚定行首

      $ :锚定行尾。技巧:"^$"用于匹配空白行。

      \b或\<:锚定单词的词首。如"\blike"不会匹配alike,但是会匹配liker

      \b或\>:锚定单词的词尾。如"\blike\b"不会匹配alike和liker,只会匹配like

      \B :与\b作用相反。

    分组及引用:

      \(string\) :将string作为一个整体方便后面引用

        \1 :引用第1个左括号及其对应的右括号所匹配的内容。

        \2 :引用第2个左括号及其对应的右括号所匹配的内容。

        \n :引用第n个左括号及其对应的右括号所匹配的内容。

扩展正则模式匹配

  匹配字符:

      跟基本正则用法一样

  匹配次数:

      {m,n} :匹配其前面出现的字符至少m次,至多n次。
      ? :匹配其前面出现的内容0次或1次,等价于\{0,1\}。
      * :匹配其前面出现的内容任意次,等价于\{0,\},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。

      +:匹配前面出现的内容1次或1次以上

  位置锚定:

      跟基本正则用法一样

  分组及引用:

      (string) :将string作为一个整体方便后面引用

        \1 :引用第1个左括号及其对应的右括号所匹配的内容。

        \2 :引用第2个左括号及其对应的右括号所匹配的内容.

        \n :引用第n个左括号及其对应的右括号所匹配的内容。

  扩展增用法:

      str | num:匹配 str 或 num 内容

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

[root@cloud ~]# sed -r "/^[[:space:]]*$/d" /etc/grub2.cfg

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

[root@cloud ~]# sed -r "/^# *|^$/d" /etc/fstab

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

[root@cloud ~]# sed -r -n "/^[^#]/s/(.*)/#\1/p" /etc/fstab

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

[root@cloud ~]# echo /etc/fstab | sed -r "s@(.*/)(.*$)@\2@"

5.利用sed取出ifconfig命令中本机的IPv4地址

[root@cloud ~]# ifconfig eth0 | sed -r -n "s/.*inet (.*) net.*/\1/p"

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

[root@cloud ~]# mount /dev/cdrom /opt/dvd
[root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.rpm$//" | sed -r "s/.*\.(.*)/\1/" | sort | uniq -c
[root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.*\.(.*).rpm/\1/" | sort | uniq -c

7.将文本文件的n和n+1行合并为一行,n为奇数行

[root@cloud ~]# seq |xargs -n2
[root@cloud ~]# seq |sed 'N;s/\n/ /'

Linux sed命令 -- 三剑客老二的更多相关文章

  1. linux sed命令参数及用法详解

    linux sed命令参数及用法详解 http://blog.csdn.net/namecyf/article/details/7336308 1. Sed简介 sed 是一种在线编辑器,它一次处理一 ...

  2. [转帖]linux sed命令

    linux sed命令就是这么简单 https://www.cnblogs.com/wangqiguo/p/6718512.html 用到的最多的就是一个sed -i 's/nn/mm/' 的命令了. ...

  3. 理解linux sed命令

    理解linux sed命令(2010-02-27 18:21:20) 标签:linuxshellsed替换 分类:革命本钱 1. Sed简介sed是一种在线编辑器,它一次处理一行内容.处理时,把当 前 ...

  4. 【转】linux sed命令

    转自:linux sed命令就是这么简单 参考:Linux三大剑客之sed:https://blog.csdn.net/solaraceboy/article/details/79272344 阅读目 ...

  5. Linux awk命令 --三剑客老大

    Linux awk命令 --三剑客老大 基本用法: awk  [参数]  ['找谁{干啥}']  文件 参数: -F 分隔符 -v 创建或修改awk变量 OFS 输出分割符 awk显示每一列的时候分隔 ...

  6. Linux sed命令 以行为单位编辑文本,或替换文本中的文字

    sed -e 4a\newLine testfile 首先查看testfile中的内容如下: $ cat testfile #查看testfile 中的内容 HELLO LINUX! Linux is ...

  7. Linux sed命令使用方法

    sed(Stream Editor)是Linux中文本处理使用非常广泛的工具,可以对文件内容进行替换.删除.新增.选取特定行等功能.下面通过sed常用实例介绍sed命令的使用方法. sed基本语法 s ...

  8. linux sed命令(擅长输出行)(转)

    linux命令总结sed命令详解 Sed 简介 sed 是一种新型的,非交互式的编辑器.它能执行与编辑器 vi 和 ex 相同的编辑任务.sed 编辑器没有提供交互式使用方式,使用者只能在命令行输入编 ...

  9. linux sed命令详解

    简介 sed 是一种在线编辑器,它一次处理一行内容.处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的 ...

随机推荐

  1. [Spark] Spark 3.0 Accelerator Aware Scheduling - GPU

    Ref: Spark3.0 preview预览版尝试GPU调用(本地模式不支持GPU) 预览版本:https://archive.apache.org/dist/spark/spark-3.0.0-p ...

  2. IDEA 2017 安装和破解

    IDEA 2017 下载地址 链接:http://pan.baidu.com/s/1qXNa9UO 密码:9wwg 激活注册码:http://xidea.online 1-选择安装地址 2-选择安装的 ...

  3. Python之网络模型与图形绘制工具networkx

    笔记 # https://www.jianshu.com/p/e543dc63454f import networkx as nx import matplotlib.pyplot as plt ## ...

  4. 软件开发的SOLID原则

    再次回顾以前潘加宇老师将的软件开放的原则. SOLID: 单一责任原则 S 开放封闭原则 O 里氏代换原则 L 接口分离原则 I 依赖反转原则 D 所有编程都是维护编程,因为你很少写原创代码.只有你在 ...

  5. Postman配置环境变量添加token

    postman测试接口时,每次都需要获取token以后,复制到接口里,特别复杂. 这里通过把获取token接口的返回数据添加到环境变量,然后将环境变量名设置在其他接口的token中,获取一次token ...

  6. 随机森林之oob的计算过程

    随机森林有一个重要的优点就是,没有必要对它进行交叉验证或者用一个独立的测试集来获得误差的一个无偏估计.它可以在内部进行评估,也就是说在生成的过程中就可以对误差建立一个无偏估计. 随机森林在生成每颗决策 ...

  7. 论文阅读 | Universal Adversarial Triggers for Attacking and Analyzing NLP

    [code] [blog] 主要思想和贡献 以前,NLP中的对抗攻击一般都是针对特定输入的,那么他们对任意的输入是否有效呢? 本文搜索通用的对抗性触发器:与输入无关的令牌序列,当连接到来自数据集的任何 ...

  8. 什么时候该使用SUM()函数

    SUM函数用于返回表达式中所有值的和.通常情况下,对某些数据进行汇总时会用到该函数. 语法:SELECT SUM(column_name) FROM table_name

  9. Web循环监控Java调用 / Java调用.net wcf接口

    背景介紹 (Background Introduction) 目前有一些报表客户抱怨打不开 报表执行过程过长,5.8.10秒甚至更多 不能及时发现和掌握服务器web站点情况 用戶需求(User Req ...

  10. Recordset对象的Open方法

    Recordset对象的Open方法原型: Open([Source],[ActiveConnection],[CursorType],[LockType],[Options]) CursorType ...