如果有一個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 -v aaa abc.txt
這個方法,是無法將修改的結果寫入abc.txt中去的。
[asp@BJ-CP-7F-106-36 result]$ cat 11371_mobile_20110425.csv20110425,北京,北京,1366118998320110425,北京,北京,15810705979WAPSJBBI_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,北京,北京,1366118998320110425,北京,北京,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/'d example-----刪除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。
cat init.ora | grep -v ^#|grep 亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb