格式:

  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. Introduction to statistical learning:with Applications in R (书,数据,R代码,链接)

    http://faculty.marshall.usc.edu/gareth-james/ http://faculty.marshall.usc.edu/gareth-james/ISL/

  2. phoenix创建表失败:phoenixIOException: Max attempts exceeded

    下面的问题,搞了1天才解决,太坑了,在这里记录一下. 问题现像:执行命令后,1分钟没有返回, 然后报下面的错,偶尔会出现以下不同的报错信息. jdbc:phoenix:10.0.xx.1:2181&g ...

  3. kubeadm安装集群系列-3.添加工作节点

    添加工作节点 worker通过kubeadm join加入集群,加入所需的集群的token默认24小时过期 查看Token kubeadm token list # 如果失效创建一个新的 kubead ...

  4. 【图像处理】FFmpeg-0

    FFmpeg是相当强大的多媒体编解码框架,在深入分析其源代码之前必须要有基本的多媒体基础知识,否则其源代码会非常晦涩难懂.本文将从介绍一些基本的多媒体只是,主要是为研读ffmpeg源代码做准备,比如一 ...

  5. python 爬虫 基于requests模块发起ajax的post请求

    基于requests模块发起ajax的post请求 需求:爬取肯德基餐厅查询http://www.kfc.com.cn/kfccda/index.aspx中指定某个城市地点的餐厅数据 点击肯德基餐厅查 ...

  6. jstat 命令

    NAME jstat - Monitors Java Virtual Machine (JVM) statistics. This command is experimental and unsupp ...

  7. 【Python】【demo实验22】【练习实例】【猴子吃桃问题】

    原题: 猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个.以后每天早上都吃了前一天剩下的一半零一个.到第10天早上想再吃时,见只 ...

  8. 啃掉Hadoop系列笔记(04)-Hadoop运行模式之伪分布式模式

    伪分布式模式等同于完全分布式,只是她只有一个节点. 一) HDFS上运行MapReduce 程序 (1)配置集群 (a)配置:hadoop-env.sh Linux系统中获取jdk的安装路径:

  9. 【C++11应用】基于C++11及std::thread实现的线程池

    目录 基于C++11及std::thread实现的线程池 基于C++11及std::thread实现的线程池 线程池源码: #pragma once #include <functional&g ...

  10. 老贾的幸福生活day3 之markdown常用语法简要

    1.markdown常用语法 标题 一级到六级 用#+空格实现 2.代码块 3个 `实现 python is a ...... 单行代码,用"``" 3.列表 有序列表 跟内容 数 ...