shell常用命令之sed用法介绍
sed是Linux中一款强大流式文本处理工具,支持按行,按字段,按正则匹配进行文本的增删改查。以下是对sed用法的详细介绍:
一、sed的使用语法
调用sed的语法有两种:
1、在命令行指定sed指令对文本进行处理:sed [参数选项] sed指令 文件名称
2、在指令脚本中指定sed指令对文本进行处理:sed [参数选项] -f 指令脚本 文件名称
二、sed常用选项
1. -r:解析扩展正则表达式(. * ? + ^ $ \ () {} [] [^])
2. -e: 将下一个参数解析为sed指令,只有当出现多个指令时才使用-e选项(指令脚本的另一种比较冗长的写法)
3. -n:取消默认输出,sed默认会输出所有内容,使用-n之后只会输出被处理过的行
4. -f script-file:指定sed要执行的脚本文件
5. -i[SUFFIX]:直接对源文件进行修改,如果使用了后缀,则会以指定的后缀备份源文件(原理:将sed命令输出内容直接重定向到源文件)
三、sed中的编辑命令
1.a text:追加,向匹配行后面追加内容text
2.c text:替换,将匹配行整行替换为text
3.i text:插入,向匹配行前面插入内容text
4.d:伤处,删除匹配行的整行内容
5.s/source/target/g:替换,将匹配的内容source替换为目标内容target
6.p:打印,打印匹配的行,通常与-n一起使用
7.=:用来打印被匹配行的行号
8.n:读取下一行,遇到n时,会自动读取下一行
9.y/source/target/:字符转换,将source转换为target
四、sed命令操作实践
准备源文件内容如下:
1.向文件中添加或者插入行:a i
sed '3athis is a new line' sed_test.txt: 向第3行后面插入‘this is a new line’
sed '/disabled/athe last line of treasure made a disabled' sed_test.txt 向匹配‘/disabled/’的行后面追加内容
sed ‘/$athis is the end of this file/’sed_test.txt 向文件最后一行后面追加一行内容,$匹配最后一行
sed '3ithis is a new line' sed_test.txt 在第3行前面插入一行
sed '/disabled/ithe line of treasure made a disabled' sed_test.txt 在匹配'/disabled/'的行前面插入一行
sed '$ithis is the end of the file' sed_test.txt 在最后一行前面插入一行
2.更改文件中匹配的行: c
sed '1cthis is a new line' sed_test.txt 将第1行替换为:this is a new line
sed '/disabled/cthis is a new line' sed_test.txt 将匹配‘/disabled/’的行替换为: this is a new line
sed '$cthis is the end of the file' sed_test.txt 将文件中最后一行替换为this is the end of the file
3.删除文件中匹配的行
sed '3d' sed_test.txt 删除文件中的第3行
sed '1~2d' sed.test.txt 从第一行开始,然后每隔2行删除一次,删除奇数行
sed '1,3d' sed_test.txt 删除第3到第3行
sed '1,3!d' sed_test.txt 删除1-3之外的所有行
sed '$d' sed_test.txt 删除最后一行
sed ‘/disabled/d’sed_test.txt 删除匹配‘/disabled/’的行
sed '/disabled/,$d' sed_test.txt 删除匹配了两个模式之间的所有行
sed '/disabled/,+nd' sed_test.txt 删除匹配行及后面n行
sed '/^$/d' sed_test.txt 删除空行(/^$/匹配空行)
sed '/disabled/!d' sed_test.txt 匹配‘/disabled/’行部删除,其他行全部删除
sed '1,6{/disabled/d}' 删除第1-6行中匹配‘/disabled/’的行
4.替换文件中的内容: s
sed 's/disabled/enabled/' sed_test.txt 替换文本中的disabled为enabled,只会替换每行中的第一个
sed 's/disabled/enabled/g' sed_test.txt 替换文本中所有的disabled
sed 's/disabled/enabled/2' sed_test.txt 替换每行中匹配的第二个disabled
sed -n 's/disabled/enabled/gpw 2.txt' 将文本中的disabled替换成enabled,打印,并写入到2.txt中
sed -n '2s/disabled/<enabled>/gp' sed_test.txt 只对第6行中的disabled进行替换
sed 's/..$/-->>/g' sed_test.txt 替换每行的最后两个字符为:-->>
sed 's/^#.*//g;/^$/d' sed_test.txt 替换文本中的所有以字符#开头的行,并删除替换后的所有空行
sed 's/disabled/(&)/g' sed_test.txt 将所有的disabled加上(),&:表示匹配的内容
sed -r 's/^([0-9]+(#))/number: \1--\2/g' sed_test.txt 将每行开头的数字替换成number: 数字--#的形式
括号编号顺序为:由外向内,由左向右,且最外层括号对应的编号应该包含内层括号中的数据
sed '1,4s/$/&hahaha/' sed_test.txt 给第1-4行的结尾加上hahaha,&表示匹配的内容
5.打印文件中的行: p
sed '1p' sed_test.txt 打印第1行
sed '1,3p' sed_test.txt 打印第1-3行
sed '2~2p' sed_test.txt 打印行号为2的行,然后行号每次+2,打印行号对应的行,简言之:打印偶数行
sed '$p' sed_test.txt 打印最后一行
sed '/disabled/p' sed_test.txt 打印匹配disabled的行
sed '3,$p' sed_test.txt 打印第3行后面所有的行
sed '/enforcing/,6p' sed_test.txt 打印匹配了‘enforcing’的行到第6行之间所有的行
sed '1,/disabled/p' sed_test.txt 打印第1行到第一个匹配了‘disabled’的行
6.打印行号
sed '$=' sed_test.txt 匹配到最后一行就先打印他的行号
sed '/disabled/=' sed_test.txt 匹配到disabled的行就先打印他的行号
五、sed的工作流程
sed的工作流程主要包括:读取,执行和显示三个过程:
读取:sed从输入流(文件,管道,标准输入流)中读取一行并存储到临时缓冲区,模式缓冲区(pattern buffer)中
执行:默认情况下,所有的sed命令都会在模式空间中按顺序执行,除非指定了行的地址,否则sed命令会在所有的行上依次执行
显示:发送修改后的内容到输出流
流、总结
1)sed在使用正则表达式的时候不能在正则表示中使用!对正则取反。
2)正则表示中不能使用!做取反操作,在正则表示中!只是一个普通的字符而已,没有其他任何意义,如果需要表示取反操作,可以在应用层使用编程逻辑实现
上一篇:移动端性能专项测试之 CPU