轉自:http://www.cnblogs.com/shineshqw/articles/1978122.html
功能說明:
利用script來處理文字檔案。
語 法:sed [-hnV][-e<script>][-f<script檔案>][文字檔案]
補充說明:sed可依照script的指令,來處理、編輯文字檔案。
參 數:
-e<script>或—expression=<script> 以選項中指定的script來處理輸入的文字檔案。
-f<script檔案>或—file=<script檔案> 以選項中指定的script檔案來處理輸入的文字檔案。
-h或—help 顯示幫助。
-n或—quiet或--silent 僅顯示script處理後的結果。
-V或—version 顯示版本資訊。
語 法:sed [-hnV][-e<script>][-f<script檔案>][文字檔案]
補充說明:sed可依照script的指令,來處理、編輯文字檔案。
參 數:
-e<script>或—expression=<script> 以選項中指定的script來處理輸入的文字檔案。
-f<script檔案>或—file=<script檔案> 以選項中指定的script檔案來處理輸入的文字檔案。
-h或—help 顯示幫助。
-n或—quiet或--silent 僅顯示script處理後的結果。
-V或—version 顯示版本資訊。
sed 編輯命令 p 列印匹配行 = 顯示檔案行號 a\ 在定位行號後附加新文字資訊 i\ 在定位行號後插入新文字資訊 d 刪除定位行 c\ 用新文字替換定位文字 s 使用替換模式替換相應模式 r 從另一個檔案中讀文字 w 寫文字到一個檔案 q 第一個模式匹配完成後推出或立即推出 l 顯示與八進位制A S C I I程式碼等價的控制字元 { } 在定位行執行的命令組 n 從另一個檔案中讀文字下一行,並附加在下一行 g 將模式2貼上到/pattern n/ y 傳送字元 n 延續到下一輸入行;允許跨行的模式匹配語句
$ sed -n -e '/music/p' -e '/music/=' a.txt
將a.txt中含有music字樣的行列印出來,並顯示出行號
$ sed '/music/a\I like music' a.txt
在a.txt中含有music字樣的行後插入一行,內容為I like music
$ sed -e 's/123/1234/' a.txt
將a.txt檔案中所有行中的123用1234替換(-e表示命令以命令列的方式執行;引數s,表示執行替換操作)
將a.txt檔案中所有行中的123用1234替換(-e表示命令以命令列的方式執行;引數s,表示執行替換操作)
$ sed '1,2 w b.txt' a.txt
將a.txt檔案中的第1,2行儲存為檔案,檔名為b.txt
$ echo "Mr Willis" | sed 's/Mr /& Bruce/g'
輸出為:Mr BruceWills
$ echo "accounts"|sed 's/$/.doc/g'
輸出為:accounts.doc
$ sed '/music/r b.txt' a.txt
將b.txt的內容插入到a.txt中含有music字樣的行後
$ sed -n -e '=' -e 'p' abc.txt 或 sed -n '=;p' abc.txt
將abc.txt中的內容顯示出來。格式為:行號\t\r對應行的內容
$ sed -e '3,5 a4' a.txt
將a.txt檔案中的3行到5行之間所有行的後面新增一行內容為4的行(引數a,表示新增行,引數a後面指定新增的內容)
將a.txt檔案中的3行到5行之間所有行的後面新增一行內容為4的行(引數a,表示新增行,引數a後面指定新增的內容)
$ sed -e '1 s/12/45/' a.txt
把第一行的12替換成45
把第一行的12替換成45
$ echo '<b>This</b> is what <b>I</b> mean.' | sed 's/<[^>]*>//g'
輸出為:This is what I mean. 中括號裡的^>表示除>之外的其他字元。
$ echo "eeny meeny miny"|sed 's/\(.*\) \(.*\) \(.*\)/Victor \1-\2 Von \3/'
輸出為:Victor eeny-meeny Von miny 小括號將感興趣的區域定義出來,第1個區域以\1表示。
$ sed -i "s/oldstring/newstring/g" `grep oldstring -rl yourdir`
批量處理通過grep搜尋出來的所有文件,將這些文件中所有的oldstring用newstring替換(-i參數列示直接對目標檔案操作)
批量處理通過grep搜尋出來的所有文件,將這些文件中所有的oldstring用newstring替換(-i參數列示直接對目標檔案操作)
$ sed -n 's/^test/mytest/p' example.file
(-n)選項和p標誌一起使用表示只列印那些發生替換的行。也就是說,如果某一行開頭的test被替換成mytest,就列印它。(^這是正規表示式中表示開頭,該符號後面跟的就是開頭的字串)(引數p表示列印行)
(-n)選項和p標誌一起使用表示只列印那些發生替換的行。也就是說,如果某一行開頭的test被替換成mytest,就列印它。(^這是正規表示式中表示開頭,該符號後面跟的就是開頭的字串)(引數p表示列印行)
$ sed 's/^wangpan/&19850715/' example.file
表示被替換換字串被找到後,被替換的字串通過&符號連線給出的字串組成新字元傳替換被替換的字串,所有以wangpan開頭的行都會被替換成它自已加19850715,變成wangpan19850715
表示被替換換字串被找到後,被替換的字串通過&符號連線給出的字串組成新字元傳替換被替換的字串,所有以wangpan開頭的行都會被替換成它自已加19850715,變成wangpan19850715
$ sed -n 's/\(love\)able/\1rs/p' example.file
love 被標記為1,所有loveable會被替換成lovers,而且替換的行會被列印出來。需要將這條命令分解,s/是表示替換操作,\(love\)表示選 中love字串,\(love\)able/表示包含loveable的行,\(love\)able/\1表示love字串標記為1,表示在替換過程中不變。rs/表示替換的目標字串。這條命令的操作含義:只列印替換了的行
love 被標記為1,所有loveable會被替換成lovers,而且替換的行會被列印出來。需要將這條命令分解,s/是表示替換操作,\(love\)表示選 中love字串,\(love\)able/表示包含loveable的行,\(love\)able/\1表示love字串標記為1,表示在替換過程中不變。rs/表示替換的目標字串。這條命令的操作含義:只列印替換了的行
$ sed 's#10#100#g' example.file
不論什麼字元,緊跟著s命令的都被認為是新的分隔符,所以,“#”在這裡是分隔符,代替了預設的“/”分隔符。表示把所有10替換成100。
不論什麼字元,緊跟著s命令的都被認為是新的分隔符,所以,“#”在這裡是分隔符,代替了預設的“/”分隔符。表示把所有10替換成100。
$ sed -n '/love/,/unlove/p' example.file
只列印包含love字串行到包含unlove字串行之間的所有行(確定行的範圍就是通過逗號實現的)
只列印包含love字串行到包含unlove字串行之間的所有行(確定行的範圍就是通過逗號實現的)
$ sed -n '5,/^wang/p' example
只列印從第五行開始到第一個包含以wang開始的行之間的所有行
只列印從第五行開始到第一個包含以wang開始的行之間的所有行
$ sed '/love/,/unlove/s/$/wangpan/' example.file
對於包含love字串的行到包含unlove字串之間的行,每行的末尾用字串wangpan替換。
字串$/表示以字串結尾的行,$/表示每一行的結尾,s/$/wangpan/表示每一行的結尾新增wangpan字串
對於包含love字串的行到包含unlove字串之間的行,每行的末尾用字串wangpan替換。
字串$/表示以字串結尾的行,$/表示每一行的結尾,s/$/wangpan/表示每一行的結尾新增wangpan字串
$ sed -e '11,53d' -e 's/wang/pan/' example.file
(-e)選項允許在同一行裡執行多條命令。如例子所示,第一條命令刪除11至53行,第二條命令用pan替換wang。命令的執行順序對結果有影響。如果兩個命令都是替換命令,那麼第一個替換命令將影響第二個替換命令的結果。(引數d,表示刪除指定的行)
(-e)選項允許在同一行裡執行多條命令。如例子所示,第一條命令刪除11至53行,第二條命令用pan替換wang。命令的執行順序對結果有影響。如果兩個命令都是替換命令,那麼第一個替換命令將影響第二個替換命令的結果。(引數d,表示刪除指定的行)
$ sed --expression='s/wang/pan/' --expression='/love/d' example.file
一個比-e更好的命令是--expression。它能給sed表示式賦值。
一個比-e更好的命令是--expression。它能給sed表示式賦值。
$ sed '/wangpan/r file' example.file
file裡的內容被讀進來,顯示在與wangpan匹配的行後面,如果匹配多行,則file的內容將顯示在所有匹配行的下面。引數r,表示讀出檔案,後面空格緊跟檔名稱
file裡的內容被讀進來,顯示在與wangpan匹配的行後面,如果匹配多行,則file的內容將顯示在所有匹配行的下面。引數r,表示讀出檔案,後面空格緊跟檔名稱
$ sed -n '/test/w file' example.file
在example.file中所有包含test的行都被寫入file裡。引數w,表示將匹配的行寫入到指定的檔案file中
在example.file中所有包含test的行都被寫入file裡。引數w,表示將匹配的行寫入到指定的檔案file中
$ sed '/^test/a\oh! My god!' example.file
'oh! My god!'被追加到以test開頭的行的後面,sed要求引數a後面有一個反斜槓。
'oh! My god!'被追加到以test開頭的行的後面,sed要求引數a後面有一個反斜槓。
$ sed '/test/i\oh! My god!' example.file
'oh! My god!'被追加到包含test字串行的前面,引數i表示新增指定內容到匹配行的前面,sed要求引數i後面有一個反斜槓
'oh! My god!'被追加到包含test字串行的前面,引數i表示新增指定內容到匹配行的前面,sed要求引數i後面有一個反斜槓
$ sed '/test/{ n; s/aa/bb/; }' example.file
如果test被匹配,則移動到匹配行的下一行,替換這一行的aa,變為bb。引數n,表示讀取匹配行的下一個輸入行,用下一個命令處理新的行而不是匹配行。Sed要求引數n後跟分號
如果test被匹配,則移動到匹配行的下一行,替換這一行的aa,變為bb。引數n,表示讀取匹配行的下一個輸入行,用下一個命令處理新的行而不是匹配行。Sed要求引數n後跟分號
$ sed '1,10y/abcde/ABCDE/' example.file
把1—10行內所有abcde轉變為大寫,注意,正規表示式元字元不能使用這個命令。引數y,表示把一個字元翻譯為另外的字元(但是不用於正規表示式)
把1—10行內所有abcde轉變為大寫,注意,正規表示式元字元不能使用這個命令。引數y,表示把一個字元翻譯為另外的字元(但是不用於正規表示式)
$ sed -i 's/now/right now/g' test_sed_command.txt
表示直接操作檔案test_sed_command.txt,將檔案test_sed_command.txt中所有的now用right now替換。引數-i,表示直接操作修改檔案,不輸出。
表示直接操作檔案test_sed_command.txt,將檔案test_sed_command.txt中所有的now用right now替換。引數-i,表示直接操作修改檔案,不輸出。
$ sed '2q' test_sed_command.txt
在列印完第2行後,就直接退出sed。引數q,表示退出
在列印完第2行後,就直接退出sed。引數q,表示退出
$ sed -e '/old/h' -e '/girl-friend/G' test_sed_command.txt
首先了解引數h,拷貝匹配成功行的內容到記憶體中的緩衝區。在瞭解引數G,獲得記憶體緩衝區的內容,並追加到當前模板塊文字的後面。上面命令列的含義:將包含 old字串的行的內容儲存在緩衝區中,然後將緩衝區的內容拿出來新增到包含girl-friend字串行的後面。隱含要求蒐集到緩衝區的匹配行在需要新增行的前面。
首先了解引數h,拷貝匹配成功行的內容到記憶體中的緩衝區。在瞭解引數G,獲得記憶體緩衝區的內容,並追加到當前模板塊文字的後面。上面命令列的含義:將包含 old字串的行的內容儲存在緩衝區中,然後將緩衝區的內容拿出來新增到包含girl-friend字串行的後面。隱含要求蒐集到緩衝區的匹配行在需要新增行的前面。
$ sed -e '/test/h' -e '/wangpan/x' example.file
將包含test字串的行的內容儲存在緩衝區中,然後再將緩衝區的內容替換包含wangpan字串的行。引數x,表示行替換操作。隱含要求蒐集到緩衝區的匹配行在需要被替換行的前面。
將包含test字串的行的內容儲存在緩衝區中,然後再將緩衝區的內容替換包含wangpan字串的行。引數x,表示行替換操作。隱含要求蒐集到緩衝區的匹配行在需要被替換行的前面。