多行命令
三个可用来处理多行文本的特殊命令:
N:
将数据流中的下一行加进来创建一个多行组
D:
删除多行组中的一行
P:
打印多行组中的一行
模式空间:
sed编辑器的工作空间
单行next命令 n
n
小写的n命令告诉sed编辑器移动到数据的下一行
# 删除首行之后的空行
$cat date1.txt
This is the header line.
this is a data line.
this is the last line.
$
$sed -n '/^$/d' date1.txt # 该命令会删除date1.txt 中所有的空行
$sed -n '/header/{n; d}' date1.txt # 删除首行后的一行, n-移动到下一行,d-删除改行, {} 命令组合
多行next命令 N
N
大写的N会将下一行文本添加到模式空间中已有的文本后
$cat date3.txt
On Tuesday, the Linux System
Administrator's group mettint will be held.
All System Administrators should attend, that's good.
$sed 'N; s/System.Administrators/Desktop users/' date3.txt # . 匹配空格或者换行符
# 若最后一行为单行,无法匹配下一行,则用下面的方法
$sed -e 's/System Administrators/Desktop users/; N; s/System\nAdministrators/Desktop users/' date3.txt
多行删除命令
D
只删除模式空间的第一行,会删除到换行符(包含换行符)为止的所有字符
#删除目标字符串所在行的前一行
cat date5.txt
this is header
this is second
####
sed '/^$/{N; /header/D}' date5.txt
多行打印命令
P
只打印模式空间的第一行
# 只打印system 这一行,匹配的是这两行
sed -n 'N; /system\nAdministrator/P' data3.txt
保持空间
*模式空间
:一块活跃的缓冲区,保持sed待检查的文本
*保持空间
:另外一个缓冲区,可以临时保存一些行
sed 保持空间的一些命令
命令 | 描述 |
---|---|
h | 将模式空间赋值到保持空间 |
H | 将模式空间附加到保持空间 |
g | 将保持空间复制到模式空间 |
G | 将保持空间附加到模式空间 |
x | 交换模式空间和保持空间的内容 |
cat data2.txt
header
first
second
last
$sed -n '/first/{h; p; n; p; g; p}' data2.txt
#first
#second
#first
排除命令
感叹号!
用来排除命令
sed -n '/header/!p' data2.txt
打印除匹配到header的所有行
# 利用模式空间和保持空间反转一个文本
sed -n '1!G ; h ; $p' data2.txt
# 另外一个倒序显示命令
tac 倒序显示
cat 正序显示
改变流-分支
[address]b [label] adderss
决定哪些行触发分支命令,label定义要跳转的位置,未加则跳转到脚本的结尾, label
不超过七个字符
# 2.3两行不执行替换命令
sed '{2,3b ; s/This is/is this/; s/line./test?/}' data2.txt
# 迭代删除文本中的第一个逗号, b之前如果不加模式匹配,则为死循环
echo "this, is, a, test, to, remove, commas." |
sed -n '{:start; s/,//1p; /,/b start}'
改变流-测试
[address]t [label]
测试命令会根据替换命令的结果跳转到某个标签
echo "this, is, a, test, to, remove, commas." |
sed -n '{:start; s/,//1p; t start}'
模式代替
# 不能正确替换
echo "the cat has a hat" | sed 's/.at/".at"/g'
# & 可以用来代替替换命令中的匹配模式
echo "the cat has a hat" | sed 's/.at/"&"/g' # the "cat" has a "hat"
# 替代单独的单词,定义替换模式的子模式
# sed 编辑器用圆括号定义替换模式的子模式, 会给第一个子模式分配字符 \1 ,第二个 \2...
echo "the cat has a hat" | sed 's/\(cat\) has/\1 had/' # the cat had a hat
echo "1234567" | sed '{:start; s/\(.*[0-9]\)\([0-9]\{3\}\)/\1,\2/; t start}'
# 1,234,567
创建sed实用工具
# 加倍行间距
sed 'G' data2.txt # sed启动时,保持空间只有一个空行
sed '$!G' data2.txt # 最后一行不加空行
# 对可能含有空白行的文件加倍行间距
sed '/^$/d; $!G' data2.txt
# 给文件中的行编号
sed '=' data2.txt | sed '{N; s/\n/ /}'
# 打印末尾行
sed '{:start; $q; N; 11,$D; b start}' data2.txt # 打印末尾10行的内容
#删除连续的空白行
sed '/./,/^$/!d' data2.txt
# 删除开头的空白行
sed '/./,$!d'
# 删除结尾的空白行
sed '{:start; /^\n*$/{$d; N; b start}}' data2.txt
#删除html标签
sed 's/<[^>]*>//g' data3.txt