sed 扩展

打印某行到某行之间的内容

例如:有个文件test的内容以下:
ert
fff
**
[abcfd]
123
324
444
[rty]
**
fgfgf
怎么能截取
[abcfd]
123
324
444
[rty]
这一部分出来呢?
答案: sed -n '/\[abcfd\]/,/\[rty\]/p' testspa

sed转换大小写

sed中,使用\u表示大写,\l表示小写
1. 把每一个单词的第一个小写字母变大写:
sed 's/\b[a-z]/\u&/g' filename
2. 把全部小写变大写:
sed 's/[a-z]/\u&/g' filename
3. 大写变小写:
sed 's/[A-Z]/\l&/g' filename字符串

sed在某一行最后添加一个数字

sed 's/\(^a.*\)/\1 12/' test
#cat  test
askdj
aslkd aslkdjf3e
skdjfsdfj
sdkfjk
fsdkfjksdjfkjsdf
12sdfesdf
aslkdjfkasdjf asdlfkjaskdfj
#sed 's/\(^a.*\)/\1 12/' test
askdj 12
aslkd aslkdjf3e  12
skdjfsdfj
sdkfjk
fsdkfjksdjfkjsdf
12sdfesdf
aslkdjfkasdjf asdlfkjaskdfj  12test

删除某行到最后一行

[root@test200 ~]# cat test
a
b
c
d
e
f
[root@test200 ~]# sed '/c/{p;:a;N;$!ba;d}' test
a
b
c

定义一个标签a,匹配c,而后N把下一行加到模式空间里,匹配最后一行时,才退出标签循环,而后命令d,把这个模式空间里的内容所有清除。

if 匹配"c"
:a
追加下一行
if 不匹配"$"
goto a
最后退出循环,d命令删除。sed

打印1到100行含某个字符串的行

这个需求,其实就是sed指定行范围匹配,较少见。实现:file

sed  -n '1,100{/abc/p}'  1.txtsdk

相关文章
相关标签/搜索