Linux 删除和替换文件中某一行的方法【推荐】
如果有一个abc.txt文件,内容是:
aaa
bbb
BATBUSINESSTYPE,INSIDEID--)ONLINE;
INSIDEID--)ONLINE
ccc
ddd
eee
fff
如果要删除ddd,那么脚本可以这样写:
sed-i'/ddd/d'abc.txt
如果删除的是一个变量的值,假如变量是var,应该写成:
sed-i'/'"$var"'/d'abc.txt
至于grep-vaaaabc.txt这个方法,是无法将修改的结果写入abc.txt中去的。
[asp@BJ-CP-7F-106-36result]$cat11371_mobile_20110425.csv 20110425,北京,北京,13661189983 20110425,北京,北京,15810705979 WAPSJBBI_101> WAPSJBBI_101>spooloff; [asp@BJ-CP-7F-106-36result]$sed-i'/WAPSJBBI_101>/d'11371_mobile_20110425.csv [asp@BJ-CP-7F-106-36result]$cat11371_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命令
$sed'2d'example-----删除example文件的第二行。
$sed'2,$d'example-----删除example文件的第二行到末尾所有行。
$sed'$d'example-----删除example文件的最后一行。
$sed'/test/'dexample-----删除example文件所有包含test的行。
在看看以前我常写的sed's/|/,/g'aaa.txt>bbb.txt这个的意思就是把aaa.txt文件中所有字符串|都换成,这是怎么表示的呢?S代表字符串,g表示行内全面替换。
替换:s命令
$sed's/test/mytest/g'example
-----在整行范围内把test替换为mytest。如果没有g标记,则只有每行第一个匹配的test被替换成mytest。
$sed-n's/^test/mytest/p'example
-----(-n)选项和p标志一起使用表示只打印那些发生替换的行。也就是说,如果某一行开头的test被替换成mytest,就打印它。
$sed's/^192.168.0.1/&localhost/'example
-----&符号表示替换换字符串中被找到的部份。所有以192.168.0.1开头的行都会被替换成它自已加localhost,变成192.168.0.1localhost。
$sed-n's/able/\1rs/p'example
-----love被标记为1,所有loveable会被替换成lovers,而且替换的行会被打印出来。
$sed's#10#100#g'example
-----不论什么字符,紧跟着s命令的都被认为是新的分隔符,所以,“#”在这里是分隔符,代替了默认的“/”分隔符。表示把所有10替换成100。
catinit.ora|grep-v ^#|grep–v^* >initprod.ora
总结
以上所述是小编给大家介绍的Linux删除和替换文件中某一行的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!