天天看點

linux sed 批量替換字元串

Linux下批量替換多個檔案中的字元串的簡單方法。用sed指令可以批量替換多個檔案中的字元串。

指令如下:sed -i “s/原字元串/新字元串/g” `grep 原字元串 -rl 所在目錄`

例如:我要把 charset=gb2312 替換為 charset=UTF-8,執行指令:sed -i “s/charset=gb2312/charset=UTF-8/g” ‘grep charset=gb2312 -rl /www’ 即可。

解釋一下:

-i 表示inplace edit,就地修改檔案

-r 表示搜尋子目錄

-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

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’ example—–所有在模闆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 —–互換模式空間和保持緩沖區的内容。也就是把包含test與check的行互換。

本文轉自 bobo5900pro  51CTO部落格,原文連結:http://blog.51cto.com/bobo5900pro/1733815,如需轉載請自行聯系原作者

繼續閱讀