虚位以待(AD)
虚位以待(AD)
首页 > 操作系统 > LINUX > linux下的sed命令小结

linux下的sed命令小结
类别:LINUX   作者:码皇   来源:     点击:

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。

默认情况下,sed的所有处理行为不会影响源文件的内容;我们一般会使用sed命令来自动编辑一个或多个文件,简化对文件的循环操作;

 

一)sed使用的参数

格式: ~]# sed [-nefr] [动作]
选项与参数:
-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。

动作说明: [n1[,n2]]function
n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,举例来说,如果我的动作是需要在 10 到 20 行之间进行的,则『 10,20[动作行为] 』

function:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!


二) sed [OPTION]... 'script' [input-file]...

其中 script:
'AddressesCommand'

Addresses(地址定界):
1.空地址:对所有文件的所有行进行处理;
2.单地址:sed对于能够匹配该地址的那唯一一行进行处理;
num:表示行号;
/pattern/:能够匹配该模式的所有行;
$:表示文档最后一行
3.地址范围:
addr1,addr2:从addr1开始到addr2结束的中间所有行;
例如:2,8
first~step:从first标记的行号开始,以step所代表的数字为步长;
例如:1~2, 2~2
addr1,+N:从addr1开始,包括addr1所在行,并继续向后计算N行;
例如:2,+7相当于2,2+7
addr1,~N:从addr1开始,包括addr1所在行,向后计算addr1*N行;
例如:2,~5相当于2,2*5
/pattern1/,/pattern2/:从被pattern1匹配的第一行开始计算,一直到被/pattern2/匹配到的第一行结束;

Command(处理命令):
=:显示被模式匹配的行的行号
例如:sed -n '/^$/=' /etc/grub2.cfg
a text:在被模式匹配的行的后面追加text的内容,支持使用n换行,从而实现多行追加;
i text:在被模式匹配的行的前面插入text的内容,支持使用n换行,从而实现多行插入;
c text:将被模式匹配的行的修改为text的内容,支持使用n换行,从而实现一行变多行;
d:在模式空间中删除被模式匹配的行;这样的行不能再进行标准输出;
注意:在使用d命令的时候,不宜使用-n选项;
p:显示模式空间中被模式匹配的行;
注意:在使用p命令的时候,通常会搭配-n选项;
w filepath:将模式空间中被模式匹配的行,另存到filepath文件中;
r filepath:将filepath文件的内容追加至模式空间中被模式匹配的行之后;
!Command:在模式空间中被模式匹配的行,不执行Command命令;相反,未被模式匹配的行,参会执行Command命令
s///:查找替换,分隔符可以任意更换,只要相同即可;
s@@@, s###, s,,,
s/pattern/text/[control]
s@/etc/fstab@/etc/mtab@

pattern:计划查找并替换的内容
text:要替换的结果
control:如何进行替换
g:行内全部替换
p:显示替换成功的行
w filepath:将替换成功的行另存到filepath文件中;

支持后向引用:
s/(string)/&/
s/(string)/1/

高级编辑命令:
h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x: 把模式空间中的内容与保持空间中的内容进行互换
n: 读取匹配到的行的下一行覆盖至模式空间
N:追加匹配到的行的下一行至模式空间
d: 删除模式空间中的行
D:删除多行模式空间中的所有行

示例:
sed -n 'n;p' FILE
sed '1!G;h;$!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练习:
1. 删除/etc/grub.conf文件中行首的空白符;
sed -r ‘s@^[[:spapce:]]+@@g‘ /etc/grub.conf
2. 替换/etc/inittab文件中"id:3:initdefault:"一行中的数字为5;
sed ‘s@(id:)[0-9](:initdefault:)@152@g‘ /etc/inittab
3. 删除/etc/bashrc文件中的空白行;
sed ‘/^[[:space:]]?$/d‘ /etc/bashrc
4. 删除/etc/inittab文件中开头的#号;
sed ‘s@^#@@g‘ /etc/inittab
5. 删除某文件中开头的#号及后面的空白字符,但要求#号后面必须有空白字符;
sed -r ‘s@^#[[:space:]]+@@g‘ /etc/inittab
6. 删除某文件中以空白字符后面跟#类的行中的开头的空白字符及#;
sed -r ‘s@^[[:space:]]+#@@g‘ /etc/inittab
7. 取出一个文件路径的目录名称;
echo "/etc/rc.d/" | sed -r ‘s@^(/.*/)[^/]+/?@1@g‘
echo "/PATH/TO/FILE" | sed -r 's@/.*
8. 取出一个文件路径的基名。
echo "/etc/rc.d/" | sed ‘s@[^/]
echo "/PATH/TO/FILE" | sed -r 's@/.*/@@g'

相关热词搜索: