高效而輕鬆的sed命令
sed(stream editor)是一款高效的流編輯器,它一次只處理一行內容,處理時,把當前處理的行儲存在臨時緩衝區中,稱為“模式空間”(pattern space),接著用sed 處理緩衝區中的內容,處理完成後把緩衝區的內容送往螢幕,接著處理下一行,這樣不斷重複,直到檔案末尾。sed處理過的檔案內容並沒有改變,除非你使用重定向儲存輸出。
命令格式如下:
sed [option] 'command' input_file
其中option是可選的, 常用的option有如下幾種:
-n 使用安靜(silent)模式,只列出經過sed特殊處理的那一行(或者動作)內容; -e 直接在指令列模式上進行 sed 的動作編輯; -f 直接將 sed 的動作寫在一個檔案內, -f filename 則可以執行filename內的sed命令; -r 讓sed命令支援擴充套件的正規表示式(預設是基礎正規表示式); -i 直接修改讀取的檔案內容,而不是由螢幕輸出;
常用的命令有以下幾種:
a \: 即append追加字串,可將其後的字元加在所選擇內容的後面 c \: 取代/替換字串,可將其後內容替換至所選內容 d : 即delete刪除,該命令會將當前選中的行刪除 i \: 即insert插入字串,可將其後內容插入至所選內容前 p : print即列印,該命令會列印當前選擇的行到螢幕上 s : 替換,通常s命令的用法是這樣的:1,2s/old/new/g,將old字串替換成new字串
命令示例
假設有一個本地檔案test.txt,檔案內容如下:
[root@linuxprobe ~]$ cat test.txt this is first line this is second line this is third line this is fourth line this fifth line happy everyday end
本節將使用該檔案詳細演示每一個命令的用法。
[root@linuxprobe ~]$ sed '1a \add one' test.txt this is first line add one this is secondline this is third line this is fourth line this is fifth line happy everyday end
本例命令部分中的1表示第一行,同樣的第二行寫成2,第一行到第三行寫成1,3,用$表示最後一行,比如2,$表示第二行到最後一行中間所有的行(包含第二行和最後一行)。
本例的作用是在第一行之後增加字串”add one”,從輸出可以看到具體效果。
[root@linuxprobe ~]$ sed '1,$a \add one' test.txt this is first line add one this is second line add one this is third line add one this is fourth line add one this is fifth line add one happy everyday add one end add one
本例表示在第一行和最後一行所有的行後面都加上”add one”字串,從輸出可以看到效果。
[root@linuxprobe ~]$ sed '/first/a \add one' test.txt this is first line add one this is secondline this is third line this is fourth line this is fifth line happy everyday end
本例表示在包含”first”字串的行的後面加上字串”add one”,從輸出可以看到第一行包含first,所以第一行之後增加了”add one”
[root@linuxprobe ~]$ sed '/^ha.*day$/a \add one' test.txt this is first line this is secondline this is third line this is fourth line this is fifth line happy everyday add one end
本例使用正規表示式匹配行,^ha.*day$表示以ha開頭,以day結尾的行,則可以匹配到檔案的”happy everyday”這樣,所以在該行後面增加了”add one”字串。
i命令使用方法和a命令一樣的,只不過是在匹配的行的前面插入字串,所以直接將上面a命令的示例的a替換成i即可,在此就不囉嗦了。
[root@linuxprobe ~]$ sed '$c \add one' test.txt this is first line this is secondline this is third line this is fourth line this is fifth line happy everyday add one
本例表示將最後一行替換成字串”add one”,從輸出可以看到效果。
[root@linuxprobe ~]$ sed '4,$c \add one' test.txt this is first line this is secondline this is third line add one
本例將第四行到最後一行的內容替換成字串”add one”。
[root@linuxprobe ~]$ sed '/^ha.*day$/c \replace line' test.txt this is first line this is secondline this is third line this is fourth line this is fifth line replace line end
本例將以ha開頭,以day結尾的行替換成”replace line”。
[root@linuxprobe ~]$ sed '/^ha.*day$/d' test.txt this isfirst line this issecond line this isthird line this isfourth line this isfifth line end
本例刪除以ha開頭,以day結尾的行。
[root@linuxprobe ~]$ sed '4,$d' test.txt thisis first line thisis second line thisis third line
本例刪除第四行到最後一行中的內容。
[root@linuxprobe ~]$ sed -n '4,$p' test.txt thisis fourth line thisis fifth line happy everyday end
本例在螢幕上列印第四行到最後一行的內容,p命令一般和-n選項一起使用。
[root@linuxprobe ~]$ sed -n '/^ha.*day$/p' test.txt happy everyday
本例列印以ha開始,以day結尾的行。
實際運用中s命令式最常使用到的。
[root@linuxprobe ~]$ sed 's/line/text/g' test.txt this isfirst text this issecond text this isthird text this isfourth text this isfifth text happy everyday end
本例將檔案中的所有line替換成text,最後的g是global的意思,也就是全域性替換,如果不加g,則只會替換本行的第一個line。
[root@linuxprobe ~]$ sed '/^ha.*day$/s/happy/very happy/g' test.txt this isfirst line this issecond line this isthird line this isfourth line this isfifth line very happy everyday end
本例首先匹配以ha開始,以day結尾的行,本例中匹配到的行是”happy everyday”這樣,然後再將該行中的happy替換成very happy。
[root@linuxprobe ~]$ sed 's/\(.*\)line$/\1/g' test.txt thisis first thisis second thisis third thisis fourth thisis fifth happy everyday end
這個例子有點複雜,先分解一下。首先s命令的模式是s/old/new/g這樣的,所以本例的old部分即\(.*\)line$,sed命令中使用\(\)包裹的內容表示正規表示式的第n部分,序號從1開始計算,本例中只有一個\(\)所以\(.*\)表示正規表示式的第一部分,這部分匹配任意字串,所以\(.*\)line$匹配的就是以line結尾的任何行。然後將匹配到的行替換成正規表示式的第一部分(本例中相當於刪除line部分),使用\1表示匹配到的第一部分,同樣\2表示第二部分,\3表示第三部分,可以依次這樣引用。比如下面的例子:
[root@linuxprobe ~]$ sed 's/\(.*\)is\(.*\)line/\1\2/g' test.txt this first this second this third this fourth this fifth happy everyday end
正規表示式中is兩邊的部分可以用\1和\2表示,該例子的作用其實就是刪除中間部分的is。
原文來自:
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/69955379/viewspace-2899783/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- 輕鬆實現在家高效辦公
- 運用sed命令高效地刪除檔案的特定行
- 如何輕鬆記住 Linux 命令Linux
- 揭秘Arthas:如何輕鬆檢視入參的命令
- 高效穩定!使用ETLCloud輕鬆同步千萬資料Cloud
- 企業圖紙版本號管理更高效、更輕鬆的方法
- 種類豐富的材質庫,讓開發者建模輕鬆高效
- linux sed []命令的作用Linux
- Linux命令篇 - sed 命令Linux
- sed命令小記
- linux sed 命令Linux
- sed 命令專題
- linux sed命令Linux
- LINUX命令-sedLinux
- Visual Studio Code:輕鬆高效的開發工具 mac/win版Mac
- sed命令和find命令的結合的使用
- 使用PING命令輕鬆判斷TCP/IP故障TCP
- 輕鬆使用“Explain Shell”指令碼來理解 Shell 命令AI指令碼
- 《Linux下sed命令的使用》Linux
- 【轉】linux中的sed命令Linux
- Linux sed命令用法Linux
- sed命令用法總結
- [shell基礎]——sed命令
- linux之 sed命令Linux
- LFCS 基礎:sed 命令
- sed命令使用詳解
- 辦公室革命,教你輕鬆搞定輕鬆玩轉ExcelExcel
- Office 2021:讓工作更輕鬆,更高效 mac/win版Mac
- 輕鬆幾招你也可以架構高效能網站架構網站
- ImageSharp.Web實戰:輕鬆搭建高效圖片服務Web
- 用Rust和Pingora輕鬆構建高效負載均衡器RustGo負載
- Linux sed 命令詳解Linux
- Linux命令-Sed用法教程Linux
- if條件語句sed命令
- shell 中 grep、sed、awk 命令
- Linux sed命令詳解Linux
- sed 命令詳解及示例
- sed命令語法詳解