如果有一個(gè)abc.txt文件,內(nèi)容是:
aaa
bbb
BATBUSINESSTYPE, INSIDEID--) ONLINE;
INSIDEID--) ONLINE
ccc
ddd
eee
fff
如果要?jiǎng)h除ddd,那么腳本可以這樣寫(xiě):
sed -i '/ddd/d' abc.txt
如果刪除的是一個(gè)變量的值,假如變量是var,應(yīng)該寫(xiě)成:
sed -i '/'"$var"'/d' abc.txt
至于grep -v aaa abc.txt這個(gè)方法,是無(wú)法將修改的結(jié)果寫(xiě)入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
從結(jié)果上看怎么就2行都刪了呢?
答案是這樣的:
sed 后面那個(gè)/d是刪除的作用,寫(xiě)成sed '/WAPSJBBI_101>/d' 11371_mobile_20110425.csv其實(shí)就是在文件11371_mobile_20110425.csv里找到跟 “WAPSJBBI_101>”匹配的行,然后刪掉。因?yàn)樵闹泻小癢APSJBBI_101>”的行是2個(gè),因此就2個(gè)一口氣都刪除了。
刪除:d命令
$ sed '2d' example-----刪除example文件的第二行。
$ sed '2,$d' example-----刪除example文件的第二行到末尾所有行。
$ sed '$d' example-----刪除example文件的最后一行。
$ sed '/test/'d example-----刪除example文件所有包含test的行。
在看看以前我常寫(xiě)的sed 's/|/,/g' aaa.txt>bbb.txt 這個(gè)的意思就是把a(bǔ)aa.txt文件中所有字符串|都換成,這是怎么表示的呢?S代表字符串,g表示行內(nèi)全面替換。
替換:s命令
$ sed 's/test/mytest/g' example
-----在整行范圍內(nèi)把test替換為mytest。如果沒(méi)有g(shù)標(biāo)記,則只有每行第一個(gè)匹配的test被替換成mytest。
$ sed -n 's/^test/mytest/p' example
-----(-n)選項(xiàng)和p標(biāo)志一起使用表示只打印那些發(fā)生替換的行。也就是說(shuō),如果某一行開(kāi)頭的test被替換成mytest,就打印它。
$ sed 's/^192.168.0.1/&localhost/' example
-----&符號(hào)表示替換換字符串中被找到的部份。所有以192.168.0.1開(kāi)頭的行都會(huì)被替換成它自已加 localhost,變成192.168.0.1localhost。
$ sed -n 's/able//1rs/p' example
-----love被標(biāo)記為1,所有l(wèi)oveable會(huì)被替換成lovers,而且替換的行會(huì)被打印出來(lái)。
$ sed 's#10#100#g' example
-----不論什么字符,緊跟著s命令的都被認(rèn)為是新的分隔符,所以,“#”在這里是分隔符,代替了默認(rèn)的“/”分隔符。表示把所有10替換成100。
cat init.ora | grep -v ^#|grep
主站蜘蛛池模板:
湟中县|
蒙城县|
资兴市|
云梦县|
定结县|
南雄市|
顺昌县|
连平县|
九台市|
湘西|
清远市|
高台县|
积石山|
海宁市|
东乡|
榆社县|
万宁市|
旬邑县|
班玛县|
成安县|
富宁县|
武邑县|
平武县|
霞浦县|
泸西县|
平南县|
泰顺县|
阳泉市|
孟连|
舒城县|
罗定市|
永新县|
钟山县|
镇平县|
襄垣县|
铅山县|
南郑县|
通道|
延长县|
碌曲县|
铜鼓县|