Linux使用sed删除和替换文件中某一行的方法

2016-01-20· 44253 次浏览
如果有一个abc.txt文件,内容是: ``` aaa bbb BATBUSINESSTYPE, INSIDEID--) ONLINE; INSIDEID--) ONLINE ccc ddd eee fff ``` 如果要删除ddd,那么脚本可以这样写: ```bash sed -i '/ddd/d' abc.txt ``` 如果删除的是一个变量的值,假如变量是var,应该写成: ```bash sed -i '/'"$var"'/d' abc.txt ``` 至于grep -v aaa abc.txt这个方法,是无法将修改的结果写入abc.txt中去的。 ```bash [asp@BJ-CP-7F-106-36 result]$ cat 11371_mobile_20110425.csv 20110425,北京,北京,13661189983 20110425,北京,北京,15810705979 WAPSJBBI_101> WAPSJBBI_101>spooloff; [asp@BJ-CP-7F-106-36 result]$ sed -i '/WAPSJBBI_101>/d'11371_mobile_20110425.csv [asp@BJ-CP-7F-106-36 result]$ cat 11371_mobile_20110425.csv 20110425,北京,北京,13661189983 20110425,北京,北京,15810705979 ``` 从结果上看怎么就2行都删了呢? 答案是这样的: sed 后面那个/d是删除的作用,写成sed '/WAPSJBBI\_101>/d' 11371\_mobile\_20110425.csv其实就是在文件11371\_mobile\_20110425.csv里找到跟 “WAPSJBBI\_101>”匹配的行,然后删掉。因为原文中含有“WAPSJBBI_101>”的行是2个,因此就2个一口气都删除了。 ## 删除:d命令 ```bash $ sed '2d' example-----删除example文件的第二行。 $ sed '2,$d' example-----删除example文件的第二行到末尾所有行。 $ sed '$d' example-----删除example文件的最后一行。 $ sed '/test/'d example-----删除example文件所有包含test的行。 ``` 在看看以前我常写的sed 's/&##124;/,/g' aaa.txt>bbb.txt 这个的意思就是把aaa.txt文件中所有字符串&##124;都换成,这是怎么表示的呢?S代表字符串,g表示行内全面替换。 ## 替换:s命令 ```bash $ sed 's/test/mytest/g' example ``` 在整行范围内把test替换为mytest。如果没有g标记,则只有每行第一个匹配的test被替换成mytest。 ```bash $ sed -n 's/^test/mytest/p' example ``` (-n)选项和p标志一起使用表示只打印那些发生替换的行。也就是说,如果某一行开头的test被替换成mytest,就打印它。 ```bash $ sed 's/^192.168.0.1/&localhost/' example ``` &符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加 localhost,变成192.168.0.1localhost。 ```bash $ sed -n 's/loveable/\1rs/p' example ``` love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。 ```bash $ sed 's#10#100#g' example ``` 不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。 ``` cat init.ora &##124; grep -v ^#&##124;grep –v ^* > initprod.ora ``` 获得更多实用资源,请关注微信公众号:智慧编程 ![qrcode_for_gh_e4235e90ab22_344.jpg](https://image.xsoftlab.net/baike/articleImages/0a8c04ed90816bc9c3aa4e22f215f5fd.png)