linux中sed学习小结

简介:

sed行处理工具

1、显示文件中匹配行

cat tmp.txt|sed -n '/匹配字符正则/p' (-n是不打印全部文件)

2、显示文件第几行

cat tmp.txt|sed -n '1p' --第一行--

cat tmp.txt|sed -n '1,3p' --一到三行--

3、替换文件中字符

cat tmp.txt | sed 's/ee/ff/' 或者 sed 's/ee/ff/' tmp.txt --将tmp.txt文件中每行第一个匹配的ee替换为ff,不改变原文件--

cat tmp.txt | sed 's/ee/ff/g' 或者 sed 's/ee/ff/g' tmp.txt --将tmp.txt文件中,全部ee替换为ff,不改变原文件--sed 's/ee/ff/' tmp.txt > tmp2.txt --将tmp.txt文件中ee替换为ff,不改变原文件,新生成一个新的tmp2.txt文件--

改变原文件:sed -i 's/ee/ff/' tmp.txt

4、指定行替换

cat tmp.txt |sed '3,5s/ee/ff/' --将文件中3到5行替换ee为ff--

5、匹配行的替换

cat tmp.txt | sed '/^w/s/ee/ff/' --将tmp.txt文件中,以w开头行中的ee替换为ff--

cat tmp.txt | sed '/^w/,/^x/s/ee/ff/' --将tmp.txt文件中,以w开头到x开头之间的行的ee替换为ff--

6、批量重命名文件名例有文件:

aa.txt bb.txt cc.txt 将其重命为aa.jpg bb.jpg cc.jpg

ls |sed 's/\(.*\)\.txt/mv \1\.txt \1\.jpg/'|sh

\( )\为内存空间,将匹配的aa bb cc记录下来,\1为内存空间的第一个匹配生成mv的命令代码,通过sh执行--

7、删除匹配行--不显示出来,不修改源文件

只删除第二行:$ sed '2 d' employee.txt

删除1到4行:$ sed '1,4 d' employee.txt

删除从第二行到最后一行:$ sed '2,$ d' employee.txt

只删除奇数行:$ sed '1~2 d' employee.txt

删除所有包含'Manager'的行:$ sed '/Manager/ d' employee.txt

删除第一次包含'Jason'的行到第四行:$ sed '/Jason/,4 d' employee.txt

删除从第一次匹配'Raj'的行 到匹配'Jane'之间的行:$ sed '/Raj/,/Jane/ d' employee.txt

删除匹配'Jason'的行及它下面两行:$ sed '/Jason/,+2 d' employee.txt

一些有用的删除例子

从一个文件删除所有空行:sed '/^$/ d' employee.txt

删除所有注释行(假设注释以#开头):sed '/^#/ d' employee.txt

本文转自追光的猫博客51CTO博客,原文链接http://blog.51cto.com/ql0722/1614750如需转载请自行联系原作者

00_yatou
相关文章
|
3月前
|
Linux Perl
Linux sed
Linux sed
161 1
|
8月前
|
Linux 数据处理 Perl
11.2.5 【Linux】sed 工具
11.2.5 【Linux】sed 工具
44 0
|
9月前
|
人工智能 移动开发 前端开发
Linux sed实战
Linux sed实战
195 0
|
Unix Linux Perl
Linux三剑客老二sed
Linux三剑客老二sed
|
Linux Perl
【Linux】sed工具的使用
【Linux】sed工具的使用
82 0
【Linux】sed工具的使用
|
Linux Perl Shell
linux sed 总结
linux sed 总结
1434 0
|
Linux Perl 开发工具
Linux sed在某行前一行和后一行添加内容
转载:http://www.361way.com/sed-process-lines/2263.html linux的sed工具是十分强大的,能很容易的实现在某关键词的前一行或后一行增加内容。
2027 0
|
Linux Perl 机器学习/深度学习