sed

linux sed 批量替換字符串

 

 

Linux下批量替換多個文件中的字符串的簡單方法。用sed命令能夠批量替換多個文件中的字符串。express

命令以下:緩存

sed -i "s/原字符串/新字符串/g" `grep 原字符串 -rl 所在目錄`

例如:我要把 charset=gb2312 替換爲 charset=UTF-8,執行命令:oop

sed -i "s/charset=gb2312/charset=UTF-8/g" `grep charset=gb2312 -rl /www`

便可。post

 

解釋一下:this

-i 表示inplace edit,就地修改文件spa

-r 表示搜索子目錄code

-l 表示輸出匹配的文件名字符串

這個命令組合很強大,要注意備份文件。

 

關於 sed 的更多說明:

1. sed ‘y/1234567890/ABCDEFGHIJ/’ test_sed

test_sed的內容是:

1234567890

2345678901

3456789012

4567890123

執行後,test_sed的內容是:

ABCDEFGHIJ

BCDEFGHIJA

CDEFGHIJAB

DEFGHIJABC

注意變換關係是按兩個list的位置對應變換

2. 替換每行全部匹配

sed 's/01/Ab/g' test_sed

1234567890

23456789Ab

3456789Ab2

456789Ab23

注意:第一行的0,1沒有分別替換爲A,b

 

刪除:d命令

$ sed '2d' example

刪除example文件的第二行。

$ sed '2,$d' example

刪除example文件的第二行到末尾全部行。

$ sed '$d' example

刪除example文件的最後一行。

$ sed '/test/'d example

刪除example文件全部包含test的行。

 

替換: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/\(love\)able/\1rs/p' example
love被標記爲1,全部loveable會被替換成lovers,並且替換的行會被打印出來。

$ sed 's#10#100#g' example
不論什麼字符,緊跟着s命令的都被認爲是新的分隔符,因此,「#」在這裏是分隔符,代替了默認的「/」分隔符。表示把全部10替換成100。

 

選定行的範圍:逗號

$ sed -n '/test/,/check/p' exampl
全部在模板test和check所肯定的範圍內的行都被打印。

$ sed -n '5,/^test/p' example
打印從第五行開始到第一個包含以test開始的行之間的全部行。

$ sed '/test/,/check/s/$/sed test/' example
對於模板test和west之間的行,每行的末尾用字符串sed test替換。

 

多點編輯:e命令

$ sed -e '1,5d' -e 's/test/check/'example
(-e)選項容許在同一行裏執行多條命令。如例子所示,第一條命令刪除1至5行,第二條命令用check替換test。命令的執行順序對結果有影響。若是兩個命令都是替換命令,那麼第一個替換命令將影響第二個替換命令的結果。

$ sed --expression='s/test/check/' --expression='/love/d' example
一個比-e更好的命令是–expression。它能給sed表達式賦值。

 

從文件讀入:r命令

$ sed '/test/r file' example
file裏的內容被讀進來,顯示在與test匹配的行後面,若是匹配多行,則file的內容將顯示在全部匹配行的下面。

 

寫入文件:w命令
$ sed -n '/test/w file' example
在example中全部包含test的行都被寫入file裏。

 

追加命令:a命令

$ sed '/^test/a\\--->this is a example' example<
‘this is a example’被追加到以test開頭的行後面,sed要求命令a後面有一個反斜槓。

 

插入:i命令

$ sed '/test/i\\
new line
-------------------------' example

若是test被匹配,則把反斜槓後面的文本插入到匹配行的前面。

 

下一個:n命令

$ sed '/test/{ n; s/aa/bb/; }' example
若是test被匹配,則移動到匹配行的下一行,替換這一行的aa,變爲bb,並打印該行,而後繼續。

 

變形:y命令

$ sed '1,10y/abcde/ABCDE/' example
把1–10行內全部abcde轉變爲大寫,注意,正則表達式元字符不能使用這個命令。

 

退出:q命令

$ sed '10q' example
打印完第10行後,退出sed。

 

保持和獲取:h命令和G命令

$ sed -e '/test/h' -e '$Gexample
在sed處理文件的時候,每一行都被保存在一個叫模式空間的臨時緩衝區中,除非行被刪除或者輸出被取消,不然全部被處理的行都將打印在屏幕上。接着模式空間被清空,並存入新的一行等待處理。在這個例子裏,匹配test的行被找到後,將存入模式空間,h命令將其複製並存入一個稱爲保持緩存區的特殊緩衝區內。第二條語句的意思是,當到達最後一行後,G命令取出保持緩衝區的行,而後把它放回模式空間中,且追加到如今已經存在於模式空間中的行的末尾。在這個例子中就是追加到最後一行。簡單來講,任何包含test的行都被複制並追加到該文件的末尾。

 

保持和互換:h命令和x命令
$ sed -e '/test/h' -e '/check/x' example

相關文章
相關標籤/搜索
本站公眾號
   歡迎關注本站公眾號,獲取更多信息