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...