sed文本处理器

文本处理三剑客之一

sed(Stream Editor)简介:

sed是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(patternspace),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕(STDOUT)。然后读入下行,执行下一个循环。如果没有使诸如’D’的特殊命令,那会在两个循环之间清空模式空间,但不会清空保留空间。这样不断重复,知道文件末尾。文件内容并没有改变,除非使用重定向存储输出。

sed与我们常用的vim的区别:

sed是非交互式的,而vim是交互式的,这意味着必须将要数据执行的命令插入到命令行或要处理的脚本中。Sed在一个文件或文件集中非交互式、并且不加询问地接收一系列的命令并执行它们。sed的强大之处就是可以对文件或者文件集批量的进行删除、替换、插入追加等操作,并且非常适合于重复的编辑,这种重复编辑如果由人工完成将花费大量的时间。

sed功能:

主要用来自动编辑一个或多个文件,简化对文件的反复操作,编写转换程序等

sed用法:

sed [option]… ‘script’ inputfile…

常用选项(option)

-n 使用安静(silent)模式.sed默认的处理结果是输出到STDOUT。但是如果加上-n参数后,则只有经过sed特殊处理的哪一行或者动作才会被别出来(与‘p’连用)

-e 直接在指令列模式上进行sed的动作编辑(多点编辑,可同时执行多条操作命令)

-f 直接将sed的动作写在一个文件内,-f filename则可以执行filename内的sed动作

-r 支持使用扩展正则表达式

-i 直接修改读取的文件内容,而不是由STDOUT输出

-i.bak 备份文件并原处编辑

script:

‘地址命令’

地址界定:

1、不给地址:对全文进行处理

2、单地址:

#:指定的行,$: 最后一行

/pattern/: 被此处模式所能够匹配到的每一行

3、地址范围

#,# 从某一行到某一行

#,+# 从某一行到该行后的第几行

/pat1/,/pat2/ 从pat1匹配到的行到pat2匹配到的行

#,/pat1/ 从某一行到匹配到pat1的行

4、~: 步进

1~2 奇数行

2~2 偶数行

编辑命令:

d: 删除模式空间匹配的行,并立即启用下一轮循环

p: 打印当前模式空间内容,追加到默认输出之后

a [\]text: 在指定行后面追加文本,支持使用\n实现多行追加

将 this is a test line 追加到 以test 开头的行后面:

sed ‘/^test/a\this is a test line’ file

在 test.conf 文件第2行之后插入 this is a test line:

sed -i ‘2a\this is a test line’ test.conf

i [\]text:在行前面插入文本

将 this is a test line 追加到以test开头的行前面:

sed ‘/^test/i\this is a test line’ file

在test.conf文件第5行之前插入this is a test line:

sed -i ‘5i\this is a test line’ test.conf

c [\]text:替换行为单行或多行文本

w /path/somefile: 保存模式匹配的行至指定文件

r /path/somefile: 读取指定文件的文本至模式空间中匹配到的行后

=:为模式空间中的行打印行号

!:模式空间中匹配行取反处理

s///: 查找替换,支持使用其他分隔符,s@@@,s###

替换标记

g: 行内全局替换

p: 显示替换成功的行

w /PATH/TO/SOMEFILE: 将替换成功的行保存至文件中

sed元字符集:

^ 匹配行开始,如:/^sed/匹配所有以sed开头的行。

$ 匹配行结束,如:/sed$/匹配所有以sed结尾的行。

. 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d。

* 匹配0个或多个字符,如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。

[] 匹配一个指定范围内的字符,如/[ss]ed/匹配sed和Sed。

[^] 匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行。

\(..\) 匹配子串,保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。

& 保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。

\< 匹配单词的开始,如:/\<love/匹配包含以love开头的单词的行。

\> 匹配单词的结束,如/love\>/匹配包含以love结尾的单词的行。

x\{m\} 重复字符x,m次,如:/0\{5\}/匹配包含5个0的行。

x\{m,\} 重复字符x,至少m次,如:/0\{5,\}/匹配至少有5个0的行。

x\{m,n\} 重复字符x,至少m次,不多于n次,如:/0\{5,10\}/匹配5~10个0的行。

sed示例:

sed ‘2p’ /etc/passwd 输出所有内容并第二行多显示一次

sed -n ‘2p’ /etc/passwd 输出第二行

sed -n ‘1,4p’ /etc/passwd 输出1至4行

sed -n ‘/root/p’ /etc/passwd 显示包含root的行

sed -n ‘2,/root/p’ /etc/passwd 从第二行开始

sed -n ‘/^$/=’ file 显示空行行号

sed -n -e ‘/^$/p’ -e ‘/^$/=’ file 先输出空行,然后输出空行行号

sed ‘/root/a\superman’ /etc/passwd 行后

sed ‘/root/i\superman’ /etc/passwd 行前

sed ‘/root/c\superman’ /etc/passwd 代替行

sed ‘/^$/d’ file 删除空行

sed ‘1,10d’ file 删除1至10行

nl /etc/passwd | sed ‘2,5d’ 删除2至5行

nl /etc/passwd | sed ‘2a tea’ 第二行最后添加tea

sed -n ‘s/root/&superman/p’ /etc/passwd 单词前

sed -n ‘s/root/superman&/p’ /etc/passwd 单词后

sed -e ‘s/dog/cat/’ -e ‘s/hi/lo/’ pets 搜索dog替换成cat,然后搜索hi替换成lo

sed -i.bak ‘s/dog/cat/g’ pets 备份文件pets.bak 将原文件中的dog替换成cat

高级编辑命令:

P:打印模式空间开端至\n内容,并追加到默认输出之前

h:把模式空间中的内容覆盖至保持空间中

H:把模式空间的内容追加至保持空间中

g:从保持空间取出数据覆盖至模式空间

G:从保持空间取出数据追加至模式空间

x:把模式空间中的内容与保持空间的内容进行互换

n:读取匹配到的行的下一行覆盖至模式空间

N:读取匹配到的行的下一行追加至模式空间

d:删除模式空间中的行

D:如果模式空间包含换行符,则删除直到第一个换行符的模式空间中的文本,并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间不包含换行符,则会像发出d命令那样启动正常的新循环

sed示例:

sed -n ‘n;p’ FILE 偶数行

sed ‘1!G;h;$!d’ FILE 倒序

sed ‘N;D’ FILE 最后一行

sed ‘$!N;$!D’ FILE 最后两行

sed ‘$!d’ FILE 最后一行

sed ‘G’ FILE 每行后面加一行空行

sed ‘g’ FILE 每行被空行替换

sed ‘/^$/d;G’ FILE 先把空行删除,然后在每一行的后面添加一行空行

sed ‘n;d’ FILE 奇数行

sed -n ‘1!G;h;$p’ FILE 倒序

想了解更多sed的用法可以查看下面的网址:

http://www.gnu.org/software/sed/manual/sed.html

 

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:/89793

发表评论

登录后才能评论

联系我们

400-080-6560

在线咨询:点击这里给我发消息

邮件:1823388528@qq.com

工作时间:周一至周五,9:30-18:30,节假日同时也值班

友情链接:万达招商  万达主管  万达娱乐平台  万达娱乐注册  万达主管QQ  万达直属QQ  万达娱乐主管QQ  万达招商QQ  万达娱乐开户  万达娱乐开户