当前位置:   article > 正文

linux文本处理三剑客之sed

linux文本处理三剑客之sed

sed

本次分享重在让大家了解sed可以干哪些事情,以及日常我们可应用到什么地方;具体的命令掌握可课后自主学习;

简介

sed全称为Stream EDitor,行编辑器,同时也是一种流编辑器。可以利用sed命令对文件进行增删改查操作。

sed 会根据脚本命令来处理文本文件中的数据,此命令执行数据的顺序如下:

  1. 每次仅读取文本的一行内容;

  2. 根据提供的规则命令匹配并修改数据。注意,sed 默认不会直接修改源文件数据,而是会将数据复制到缓冲区中,修改也仅限于缓冲区中的数据;

  3. 将匹配修改后的执行结果输出。

当一行数据匹配完成后,它会继续读取下一行数据,并重复这个过程,直到将文件中所有数据处理完毕。

使用

基本格式

# sed [option] [cmd] filename # sed -n '/error/p' service.log.fls

option

常用的option及其含义:

option

含义

-n

默认情况下,sed会自动输出整个文本处理后的内容;而该option会屏蔽输出;

-i

此option会直接修改源文件,要慎用;

-e

追加命令,多个-e多条命令

-f

cmd

cmd基本格式:

# [n1[n2]] action

# n1,n2代表进行操作的行数,10,20代表在10,20行间执行命令;不指定n1,n2则默认作用于所有行;

常用的action及其含义:

action

含义

p

打印,通常会和-n一起运行,效果是只会输出匹配行

s

文本替换命令;

基本格式:s/pattern/replacement/flags

此命令中常用的 flags:

  • n:1~512 之间的数字,表示指定要替换的字符串出现第几次时才进行替换,例如,一行中有 3 个 A,但用户只想替换第二个 A,这是就用到这个标记;

  • g:对数据中所有匹配到的内容进行替换,如果没有 g,则只会在第一次匹配成功时做替换操作。例如,一行数据中有 3 个 A,则只会替换第一个 A;

  • p:会打印与替换命令中指定的模式匹配的行。此标记通常与 -n 选项一起使用;

  • w file:将缓冲区中的内容写到指定的 file 文件中;

  • &:用正则表达式匹配的内容进行替换;

a

在当前行下面插入文本

i

在当前行上面插入文本

d

删除选择的行

c

把选定的行改为新的文本

增删改查

  • 匹配关键词

  1. # 格式:sed -n '/字符串/p' 文件名
  2. sed -n '/aaa/p' service.log.fls
  3. sed -n '/aaa\|bbb/p' service.log.fls
  • 打印行号

  1. # sed -n '/aaa/=' service.log.fls
  2. # sed -n -e '/aaa/p' -e '/aaa/=' service.log.fls
  • 匹配某几行

  1. # 打印第2行到第5行 sed -n '2,5p' service.log.fls
  2. # 打印除2-5行外的内容 sed -n '2,5!p' service.log.fls
  3. # 打印第2行和第5行 sed -n '2p;5p' service.log.fls
  4. # 打印最后一行 sed -n '$p' service.log.fls
  5. # 打印匹配行以及后面2行 sed -n '/aaa/,+2p' service.log.fls
  6. # 打印匹配字符串行的下一行 sed -n '/aaa/{n;p}' service.log.fls
  7. # 从第2行开始每隔3行打印 # sed -n '2~3p' service.log.fls
  • 匹配范围

  1. # 格式:sed -n '/start_pattern/,/end_pattern/p' 文件名
  2. # 过滤出2023-03-05T23:05:002023-03-05T23:06:00的日志 sed -n '/2023-03-05T23:05:00/,/2023-03-05T23:06:00/p' service.log.fls
  3. # 备注:start_pattern和end_pattern在文件中必须存在,否则匹配不生效,会输出整个文本;

  1. 替换行内部分内容
  2. # 替换每行匹配到的第一个字符串
  3. sed -i 's/aaa/AAA/' service.log.fls
  4. # 全部替换每行匹配到的字符串
  5. sed -i 's/aaa/AAA/g' service.log.fls
  6. # 替换从第2行到最后一行匹配到的所有字符串
  7. sed -i '2,$s/aaa/AAA/g' service.log.fls
  8. # 替换第4行匹配到的字符
  9. sed -i '4s/aaa/AAA/' service.log.fls
  10. # 替换每行中匹配到的第3个字符串
  11. sed -i 's/aaa/AAA/3' service.log.fls
  12. # 将所有的doc都替换为docs,&代表查找串
  13. sed -i 's/doc/&s/g' service.log.fls

  1. # 在第2行后面加一行"hello world"
  2. sed -i '2a hello world' service.log.fls
  3. # 在第2行前面加一行"hello world"
  4. sed -i '2i hello world' service.log.fls

  1. # 删除文件包含bbb的行
  2. sed -i '/bbb/d' service.log.fls
  3. # 删除第1行和第2行
  4. sed -i '1,2d' service.log.fls

附录

参考链接:

https://blog.csdn.net/m0_37814112/article/details/120171342

http://c.biancheng.net/view/4028.html

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/一键难忘520/article/detail/784997
推荐阅读
相关标签
  

闽ICP备14008679号