shell常用命令之sed用法介绍

shell常用命令之sed用法介绍

编程文章jaq1232025-05-25 12:31:072A+A-

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)正则表示中不能使用!做取反操作,在正则表示中!只是一个普通的字符而已,没有其他任何意义,如果需要表示取反操作,可以在应用层使用编程逻辑实现

点击这里复制本文地址 以上内容由jaq123整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!

苍茫编程网 © All Rights Reserved.  蜀ICP备2024111239号-21