sed
sed
Stream EDitor, 行编辑器
sed 是一种流编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space ),接着用sed 命令处理缓冲区中的内容
,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有改变,除非你使用重定向存储输出。Sed 主要用来自动编辑一
个或多个文件, 简化对文件的反复操作,编写转换程序等
sed工具
用法:
sed [option]... 'script' inputfile...
常用选项:
-n :不输出模式空间内容到屏幕,即不自动打印
-e: 多点编辑
-f :/ PATH/SCRIPT_FILE : 从指定文件中读取编辑脚本
-r: 支持使用扩展正则表达式
-i:编辑文件并保存
-i.bak:备份文件并原处编辑
- sed替换标记
g 表示行内全面替换
p 表示打印行
w 表示把行写入一个文件
x 表示互换模板块中的文本和缓冲区中的文本
y 表示把一个字符翻译为另外的字符(但是不用于正则表达式)
\1 子串匹配标记
& 已匹配字符串标记
- script:
'地址命令' - 地址定界:
(1)不给地址:对全文进行处理
(2)单地址:
#: 指定的行
/pattern/ :被此处模式所能够匹配到的每一行
(3)地址范围:
#,#
#,+#
/pat1/,/pat2/
#,/pat1/
(4)~:步进
1~2 奇数行
2~2 偶数行
- 编辑命令:
d:删除模式空间匹配的行
p:显示模式空间中的内容
a [\]text在指定行后面追加文本支持使用\n 实现多行追加
i [\]text在行前面插入文本
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高级编辑命令
h:把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g:从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x:把模式空间中的内容与保持空间中的内容进行互换
n:读取匹配到的行的下一行覆盖至模式空间
N:读取匹配到的行的下一行追加至模式空间
d:删除模式空间中的行
D:删除当前模式空间开端至\n 的内容(不再传至标准输出),放弃之后的命令,但是对剩余模式空间重新执行sed
sed示例
sed ‘2p’ /etc/passwd
sed –n ‘2p’ /etc/passwd
sed –n ‘1,4p’ /etc/passwd
sed –n ‘/root/p’ /etc/passwd
sed –n ‘2,/root/p’ /etc/passwd 从2 行开始
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
nl /etc/passwd | sed ‘2,5d’
nl /etc/passwd | sed ‘2a tea’
sed 's/test/mytest/g' example
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
sed –i.bak ‘s/dog/cat/g’ pets
sed -n '/^h/,/^s/p' f1 显示文件中以h开头到s开头的行
sed -n '/'''$name'''/p' passwd 引用变量
sed -n '/'$(whoami)'/'
sed -n "/`whoami`/"
高级用法示例
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 逆向显示文件每一行
练习:
-
删除centos7 系统/etc/grub2.cfg 文件中所有以空白开头
的行行首的空白字符 -
删除/etc/fstab 文件中所有以# 开头,后面至少跟一个空
白字符的行的行首的# 和空白字符
sed -r 's/^#[[:space:]]+?//' /etc/fstab -
在centos6 系统/root/install.log 每一行行首增加#号
sed s/^/#/ q -
在/etc/fstab 文件中不以# 开头的行的行首增加#号
-
处理/etc/fstab 路径, 使用sed 命令取出其目录名和基名
echo "/etc/sysconfig/network-scripts" |sed -r 's@(/.*/)([/]+/?)@\2@' 目录名
echo "/etc/sysconfig/network-scripts/" | sed -r 's@(/.*/)([/]+/?)@\1@' 基名 -
利用sed 取出ifconfig 命令中本机的IPv4地址
ifconfig eth0|sed -n -e '2s/^.* r://' -e '2s/ .* //p' -
统计centos 安装光盘中Package 目录下的所有rpm 文件的
以. 分隔倒数第二个字段的重复次数 -
统计/etc/init.d/functions 文件中每个单词的出现次数,
并排序(用grep 和sed 两种方法分别实现) -
将文本文件的n 和n+1 行合并为一行,n为奇数行
-
删除空白行和#开头的行
sed -e '/^#/d' -e '/^[[:space:]]*$/d' /etc/fstab