打印某行到某行之间的内容
例如:有个文件test的内容如下:
ert fff ** [abcfd] 123 324 444 [rty] ** fgfgf 怎么能截取以下这部分出来呢? [abcfd] 123 324 444 [rty] 答案: sed -n '/\[abcfd\]/,/\[rty\]/p' testsed 转换大小写
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' filenamesed 在某一行最后添加一个数字
#sed 's/\(^a.*\)/\1 12/' test.txt删除某行到最后一行
[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命令删除。打印1到100行含某个字符串的行
这个需求,其实就是sed指定行范围匹配,较少见。实现:
sed -n '1,100{/abc/p}' 1.txt