sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间” (pattern space) ,接着用 sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。 Sed 主要用来自动编辑一个或多个文件;简化对文件的反复 *** 作;编写转换程序等。
假设处理的文本为 test.file ,在每行的头添加字符,比如 HEAD ,命令如下:
在每行的行尾添加字符,比如 TAIL ,命令如下:
几点说明:
这样就处理完了!总之恰当使用sed命令是可以避免来回打开文件造成的时间浪费,可以使用sed命令在linux脚本中做一些更好玩的事情。希望这篇文章可以给你一些帮助~
1、通常用sed关闭SELINUXsed -i 's@SELINUX=enforcing@SELINUX=disabled@' /etc/sysconfig/selinux 将enforcing替换成disabled。
2、sed -i '10d' /etc/sysconfig/selinux删除 /etc/sysconfig/selinux第10行。
3、sed -i '11a hello world' /etc/sysconfig/selinux 在第11行后增加内容hello world。
4、sed -n '/ing/p' /etc/sysconfig/selinux 查询包含关键字ing所在所有行。
5、sed -i '2c haha' /etc/sysconfig/selinux 将第二行整行替换成haha,就完成了。
用awk,一条命令就可以搞定:1
awk '{print $0" "FNR}' file.txt >result.txt
其中,$0表示当前处理的文件行内容,FNR表示当前处理的文件行行号。
结果存在result.txt中。
为拓展思路,下面用一个不同的方法:
用sed得到每行行号,存入一个tmp文件,然后用paste合并这两个行数相同的文件就得到了。
假设你的原始文件名称为file.txt。
#!/bin/sh
sed -n '=' file.txt >tmp
paste file.txt tmp >result.txt
rm -f tmp
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)