原文:

1、sed   流编辑器,实现对文字的增删改替换查(过滤、取行),能同时处理多个文件多行的内容,可以不对原文件改动,把整个文件

输入到屏幕,可以把只匹配到模式的内容输入到屏幕上。还可以对原文件改动,但是不会再屏幕上返回结果。

流程:Sed软件从文件或管道中读取一行,处理一行,输出一行;再读取一行,再处理一行,再输出一行……

模式空间:sed软件内部的一个临时缓存,用于存放读取到的内容。

2、命令格式:sed  [选项]   [命令]   [输入文件]

sed命令的常用选项:

-n :只打印模式匹配的行,一般与 p 一起使用。如:sed -n  ' 2p '  /data  表示输出/data的第二行,如:sed  -n '20,30p'    /data/boy显示 /data/boy的20到30行。

-e :进行多项编辑,即对输入行应用多条sed命令时使用,此为默认选项。如:sed -e '/^#/d'  -e '/^$/d'  /data/boy表示删除空格的行和#开头的行。

-f :将sed的动作写在一个脚本文件内,用–f filename 执行filename内的sed动作。

-r :支持扩展表达式

-i :直接修改文件内容,如:sed   -i   s#old#new#g

常用基本命令:

  d        :delete, 删除匹配到的行;
    p        :print,  显示匹配到的行;通常 p 会与参数 sed -n 一起用
    a \text:append, 在指定行后追加文本text,支持使用\n实现多行追加;
    i \text :insert, 在指定行前插入文本text,支持使用\n实现多行插入;
    c \text:将指定行的内容替换为文本text;
    w /file:write, 保存模式空间中匹配到的行至指定的文件中;

r /file :read, 将指定文件的内容读取至当前模式空间中被匹配到的行后面,常用于实现文件合并;

sed  -i '/Ethernet/r myfile' test  匹配Ethernet的行,读进来另一个文件的内容,读进来的文件的内容会插入到匹配Ethernet的行后

    s/pattern/replaces/:查找pattern用replaces替换;分隔符可自行指定,常用的分隔符有/, #, @等;
    替换标记:
            g:全局替换;
            w /file:将替换的结果保存至指定文件中;sed -i 's/pattern/replaces/w my.txt'  test    将替换后的结果保存到my.txt中
            p:显示替换成功的行;

y:用于(对应)转换字符;

    =:打印行号;
    ! :匹配后取反;
    l :打印行号,并显示控制字符;
    q:读取匹配到的行后退出;


3、sed在文件中查询文本的方式

  x/p   查询第x行   sed -n '2p' /data  
  x,y/p     查询从x到y行     sed -n '1,3p' /data  
  /pattern/p     查询包含pattern的行     sed -n '/pattern/p' /data  
  /pattern 1/,/pattern 2/p     查询包含pattern 1或pattern 2的行     sed -n '/pn1/,/pn2/p'  /data
  /pattern/,xp   查询从包含pattern的行到x行   sed -n '/pn/,5p'  /data
  x,/pattern/p   查询从x到包含pattern的行   sed -n '5,/pn/p'  /data
  x,y!p   查询不包含指定行号x和y的行   sed -n '5,8!p'  /data
  1. 10{sed-commands} 对第10行操作
  2.    10,20{sed-commands} 对10到20行操作,包括第10,20行

  3.    10,+20{sed-commands} 对10到30(10+20)行操作,包括第10,30行

  4.    1~2{sed-commands} 对1,3,5,7,……行操作

  5.    10,${sed-commands} 对10到最后一行($代表最后一行)操作,包括第10行

  6. /oldboy/{sed-commands} 对匹配oldboy的行操作

  7. /oldboy/,/Alex/{sed-commands} 对匹配oldboy的行到匹配Alex的行操作

  8. /oldboy/,${sed-commands} 对匹配oldboy的行到最后一行操作

  9. /oldboy/,10{sed-commands} 对匹配oldboy的行到第10行操作,注意:如果前10行没有匹配到oldboy,sed软件会显示10行以后的匹配oldboy的行,如果有。

  10. 1,/Alex/{sed-commands} 对第1行到匹配Alex的行操作

  11. /oldboy/,+2{sed-commands} 对匹配oldboy的行到其后的2行操作

4、案例(sed 后不跟  -i  表示仅对输出改变,对源文件不改变)

  • 单行增加到第2行后:   sed '2a 106,dandan,CSO' person.txt

  • 单行增加到第2行前:   sed '2i 106,dandan,CSO' person.txt

  • 多行增加到第2行前:   sed '2i 106,dandan,CSO\n107,bingbing,CCO' person.txt,每行之间加换行符    \n

  • 删除第二行:                   sed '2d' person.txt

  • 删除匹配oldboy或者Alex的行                  sed '/oldboy/,/Alex/d' person.txt

  • 用新行替代第2行                      sed '2c 106,dandan,CSO' person.txt

  • 分组替换\( \)和\1的使用说明

sed软件的\( \)的功能可以记住正则表达式的一部分,其中,\1为第一个记住的模式即第一个小括号中的匹配内容,\2第二记住的模

式,即第二个小括号中的匹配内容,sed最多可以记住9个。

例:echo I am oldboy teacher.如果想保留这一行的单词oldboy,删除剩下的部分,使用圆括号标记想保留的部分。

echo I am oldboy teacher. |sed 's#^.*am \([a-z].*\) tea.*$#\1#g'

思路:用oldboy字符替换I am oldboy teacher.

下面解释用代替空格:

        ^.*am□ –>这句的意思是以任意字符开头到am□为止,匹配文件中的I am□字符串;

        \([a-z].*\)□–>这句的外壳就是括号\(\),里面的[a-z]表示匹配26个字母的任何一个,[a-z].*合起来就是匹配任意

多个字符,本题来说就是匹配oldboy字符串,由于oldboy字符串是需要保留的,因此用括号括起来匹配,后面通过\1来取oldboy字符串。

        □tea.*$–>表示以空格tea起始,任意字符结尾,实际就是匹配oldboy字符串后,紧接着的字符串□teacher.;

后面被替换的内容中的\1就是取前面的括号里的内容了,也就是我们要的oldboy字符串。

        ()是扩展正则表达式的元字符,sed软件默认识别基本正则表达式,想要使用扩展正则需要使用\转义,即\(\)。sed使

-r选项则可以识别扩展正则表达式,此时使用\(\)反而会出错。

Linux正则表达式,grep总结,sed用法的更多相关文章

  1. Linux正则表达式grep与egrep

    grep -io "http:/=[A-Z0-9]\{16\}" ./wsxf.txt >wsxf_urls.txt Linux正则表达式grep与egrep 正则表达式:它 ...

  2. 【linux系统】命令学习(五)linux三剑客 grep \ awk \ sed

    grep----基于正则表达式查找满足条件的行 1.内容检索 获取行 grep pattern file 获取内容 grep -o pattern file 获取上下文grep -A -B -C pa ...

  3. Linux三剑客-grep || awk || sed

    grep是一个强大的文本搜索工具 命令格式: grep [option] pattren file -a  将二进制文档以文本方式处理 -c  计算找到的符合行的次数 -i  忽略大小写 -n  顺便 ...

  4. NO22 Linux正则表达式--grep命令常用参数

    Linux正则表达式:  一.基础正则第一波字符说明: 示例: 二.基础正则第二波字符说明:  三.基础正则第二波字符说明: 示例:  grep:一般常用参数 示例:+和*  ?和.:  |:  () ...

  5. linux中grep命令的用法

    作为linux中最为常用的三大文本(awk,sed,grep)处理工具之一,掌握好其用法是很有必要的. 首先谈一下grep命令的常用格式为:[grep  [选项]  "模式"  [ ...

  6. Linux中grep、sed、awk使用介绍

    linux文件操作命令介绍1)grepgrep 用于在文件中查找符合条件的记录grep 参数 过滤条件 文件过滤的条件中可使用正则表达式-c 显示符合的行数-i 忽略大小写-n 显示符合要求的记录,包 ...

  7. Linux正则表达式grep

    正则表达式是一种符号表示法,用于识别文本模式.Linux处理正则表达式的主要程序是grep.grep搜索与正则表达式匹配的行,并将结果输送至标准输出. 1. grep匹配模式 grep按下述方式接受选 ...

  8. linux shell grep/awk/sed 匹配tab

    处理文件的命令实在是多, sed, awk, grep等.遇到了需要匹配tab的情况, 记录一下. 例子如下:找出文本中第一列是1的行. 文本a 解法1 : 直接使用正则表达式, ^表示开头, \t表 ...

  9. linux三剑客grep,sed,awk

    grep 官方帮助文档 Usage: grep [OPTION]... PATTERN [FILE]... Search for PATTERN in each FILE or standard in ...

随机推荐

  1. web服务器请求代理方式

    1 通信数据转发程序:代理.网关.隧道 代理:是一种有转发功能的应用程序,他扮演了位于服务器和客户端“中间人”的角色,接收客户端发送的请求并转发给服务器:同时也接收服务器返回的响应并转发给客户端. 使 ...

  2. tf.image.crop_and_resize

    https://blog.csdn.net/m0_38024332/article/details/81779544 将图片剪切下来,池化为固定大小.可以快速的对proposal进行池化

  3. MongoDB学习(附录一) 安装mongodb3.6时碰到的问题

    1.Installing MongoDB Compass...(this may take a few minutes)这一步,会停留很长时间,点击取消可能也取消不了. 安装mongdodb ,进度卡 ...

  4. [LeetCode] 202. Happy Number 快乐数

    Write an algorithm to determine if a number is "happy". A happy number is a number defined ...

  5. [LeetCode] 360. Sort Transformed Array 排序转换后的数组

    Given a sorted array of integers nums and integer values a, b and c. Apply a function of the form f( ...

  6. h5上拉加载更多

    --------------------------------------------------------------------------例子1 <div class="bo ...

  7. vue-cli3 每次打包都改变css img js文件名,还有自带版本号

    let Version = new Date().getTime(); css: { // 是否使用css分离插件 ExtractTextPlugin extract: { //一种方式,打包后的cs ...

  8. socket-01

     对于所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端

  9. win10安装网络适配器

    上面这个有些叫Microsoft Loopback Adapter

  10. java-统计一段句子中各单词出现的次数

    问题:统计一段句子中各单词出现的次数. 思路: 1.使用split方法将文章进行分割,我们这里以空格.逗号和句点为分隔符,然后存到一个字符串数组中. 2.创建一个hashMap集合,key是字符串类型 ...