stream editor,用程序的方式编辑文本。基本上是玩正则模式匹配。html
$ sed "s/my/Hao Chen's/g" pets.txt
正则表达式
单引号去除全部字符的特殊意义,双引号保留某些字符的特殊意义shell
默认是将处理过的内容输出,能够加-i参数直接修改原文件
$ sed -i "s/my/Hao Chen's/g" pets.txt
spa
在每行的最前面加东西
$ sed 's/^/#/g' pets.txt
code
在每行的最后面加东西
$ sed 's/$/ --- /g' pets.txt
htm
正则表达式基本blog
^ 一行的开头 $ 同样的结尾 \< 词首 \> 词尾 . 任意单个字符 * 某个字符出现0次或屡次 [] 集合,[^]取反
去除<>中的tags
$ sed 's/<[^>]*>//g' html.txt
three
只替换第3到6行
$ sed "3,6s/my/your/g" pets.txt
字符串
只替换第一个
$ sed 's/s/S/1' my.txt
cmd
只替换第3个之后的
$ sed 's/s/S/3g' my.txt
&能够做为被匹配的变量
$ sed 's/my/[&]/g' my.txt
给my加上[]
sed '1,3s/my/your/g; 3,$s/This/That/g' my.txt
前3行一个操做,后面一个操做sed -e '1,3s/my/your/g' -e '3,$s/This/That/g' my.txt
$ sed 's/This is my \([^,&]*\),.*is \(.*\)/\1:\2/g' my.txt
sed -e ":begin; /<<</,/>>>/ { />>>/! { $! { N; b begin }; }; s/<<<.*>>>/COMMENT/; };" test
:begin;标记开头
/<<</,/>>>/ 表示后面的命令只处理<< <和> >>之间的部分,
后面的/>>>/! 表示若是当前行没有匹配到结束标记/>>>/
$表明文本的最后一行,$!表示若是当前不是最后一行
N 将下一行内容追加到缓冲区,至关于"合并"成一行
b begin 表示跳回begin处从新开始执行命令
s/<<<.*>>>/COMMENT/; 终于匹配成功,将<< <到> >>之间的内容替换为COMMENT
$ sed 'N;s/\n/,/' pets.txt
链接两行,用逗号分隔# 第一行前插入一行 $ sed "1 i This is my monkey, my monkey's name is wukong" my.txt
#最后一行后追加一行 $ sed "$ a This is my monkey, my monkey's name is wukong" my.txt
#匹配到/fish/后追加一行 $ sed "/fish/a This is my monkey, my monkey's name is wukong" my.txt
$ sed "2 c This is my monkey, my monkey's name is wukong" my.txt $ sed "/fish/c This is my monkey, my monkey's name is wukong" my.txt
$ sed '/fish/d' my.txt $ sed '2d' my.txt $ sed '2,$d' my.txt
# 默认会打印处理的信息 $ sed '/fish/p' my.txt
# -n参数只打印匹配的信息 $ sed -n '/fish/p' my.txt
# 打印从一个模式到另外一个模式的信息 $ sed -n '/dog/,/fish/p' my.txt
#从第一行打印到匹配fish成功的那一行 $ sed -n '1,/fish/p' my.txt
pattern space
sed处理文本的伪代码 ``` 对文件中每行数据 { 将一行数据放入pattern_space 对每一个pattern space执行sed命令 若是没有指定-n则输出处理后的pattern space } ```
Address
[address[,address]][!]{cmd}
address能够是一个数字,也能够是一个模式
# 可使用相对位置 $ sed '/dog/,+3s/^/# /g pets.txt'
# 第3到6行删除This的行 $ sed '3,6 {/This/d}' pets.txt # 第3到6行匹配了This,再匹配fish,则删除 $ sed '3,6 {/This/{/fish/d}}' pets.txt # 从第一行到最后一行,若是匹配到This,则删除之;若是前面有空格,则去除空格 $ sed '1,${/This/d;s/^ *//g}' pets.txt
Hold Space不一样行操做之间保持状态
g: hold space > pattern space中 G: hold space >> pattern space \n以后附加 h: pattern space > hold space H: pattern space >> hold space \n以后附加 x: 交换pattern space和hold space的内容
例若有以下文本
$ cat t.txt one two three
$sed 'H;g' t.txt one one two one two three
分析
例子2(反序输出)
$ sed '1!G;h;$!d' t.txt three two one
命令能够拆解为3个
分析