shell linux sed 批量替換字串

2021-09-29 02:20:56 字數 3283 閱讀 7005

linux sed 批量替換字串

一月 21, 2014 ( no comments )

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 『y/1234567890/abcdefghij/』 test_sed

test_sed的內容是:

執行後,test_sed的內容是:

abcdefghij

bcdefghija

cdefghijab

defghijabc

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

替換每行所有匹配

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』 exampl

所有在模板test和check所確定的範圍內的行都被列印。

$ sed -n 『5,/^test/p』 example

列印從第五行開始到第乙個包含以test開始的行之間的所有行。

$ sed 『/test/,/check/s/$/sed test/』 example

對於模板test和west之間的行,每行的末尾用字串sed test替換。

$ 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被匹配,則把反斜槓後面的文字插入到匹配行的前面。

$ sed 『/test/』 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的行互換。

mybatis批量查詢,批量新增,批量更新

一 多條件批量查詢 先上 再講解 select from ifs company where id and code id標籤不用多說,和dao方法一一對應。parametertype標籤寫list就可以,如果是其他型別對應寫就可以。resultmap,自己定義的字段實體類對應。二 批量新增 先上 ...

批量匯入是批量修改還是批量新增

1 一般基礎資料資訊的管理功能包括 新增 修改 刪除 查詢 匯入 匯出,比如物料資訊維護 這裡說到的匯入即相對於新增來說,即批量新增的功能 2 當我所有的資料資訊都完善了的情況下,由於業務的變更,需要給這些基礎資料資訊新增乙個字段資訊a 這個時候怎麼辦?3 注 在新增 修改 匯入模組都增加了字段資訊...

hibernate批量修改,批量刪除

在hibernate應用中如何處理批量更新和批量刪除?批量更新是指在乙個事務中更新大批量資料,批量刪除是指在乙個事務中刪除大批量資料。以下程式直接通過hibernate api批量更新customers表中年齡大於零的所有記錄的age欄位 tx session.begintransaction it...