Linux下批量替換多個文件中的字符串的簡單方法。用sed命令能夠批量替換多個文件中的字符串。正則表達式
命令以下:sed -i 「s/原字符串/新字符串/g」 `grep 原字符串 -rl 所在目錄`express
例如:我要把 charset=gb2312 替換爲 charset=UTF-8,執行命令:sed -i 「s/charset=gb2312/charset=UTF-8/g」 ‘grep charset=gb2312 -rl /www’ 便可。緩存
解釋一下:this
-i 表示inplace edit,就地修改文件字符串
-r 表示搜索子目錄it
-l 表示輸出匹配的文件名io
這個命令組合很強大,要注意備份文件。模板
關於 sed 的更多說明:test
1. sed ‘y/1234567890/ABCDEFGHIJ/’ test_sedsed
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’ 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的行互換。