Linux | sed 命令
阿新 • • 發佈:2021-08-29
sed 命令介紹
sed:Stream Editor 文字編輯,是一個非互動式的命令列工具,能夠完美的配合正則表示式使用,功能非常強大,處理時,把當前處理的行儲存在臨時緩衝區中,稱為“模式空間”,然後用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往螢幕,接著處理下一行,這樣不斷重複,走到檔案未尾。sed 主要用來自動編輯一個或者多個檔案 ,可以將資料行進行替換,刪除新增,選取等特定工作,簡化對檔案 的反覆操作,編寫轉換程式等。
命令格式
sed [options] 'command' file(s); sed [options] -f scriptfile file(s);
選項 | 作用 |
---|---|
-e | 直接在命令列模式上進行 sed 動作編輯,此為預設選薦 |
-f | 將sed 的動作寫在一個檔案 內,用-f filename 執行 filename內的sed動作 |
-i | 直接個性檔案的內容 |
-n | 只打印模式匹配的行 |
-r | 支援擴充套件表示式 |
-h | 顯示幫助資訊 |
-v | 顯示版本號 |
命令 | 作用 |
---|---|
a\ | 在當前行下面插入文字 |
i\ | 在當前行上面插入文字 |
c\ | 把選定的行改為新的文字 |
d | 刪除,刪除選擇的行 |
D | 刪除模板塊的第一行 |
s | 替換指定字元 |
h | 拷貝模板塊的內容到記憶體中的緩衝區 |
H | 追加模板塊的內容到記憶體中的緩衝區 |
g | 獲得記憶體緩衝區的內容,並替代當前模板塊中的文字 |
G | 獲得記憶體緩衝區的內容,並追加到當前模板塊文字的後面 |
l | 列表不能列印字元的清單 |
n | 讀取下一個輸入行,用下一個命令處理新的行而不是用第一個命令 |
N | 追加下一個輸入行到模板塊後面並在二者間嵌入一個新行,改變當前行號碼 |
p | 列印模板塊的行。 P(大寫) 列印模板塊的第一行 |
q | 退出Sed |
b lable | 分支到指令碼中帶有標記的地方,如果分支不存在則分支到指令碼的末尾 |
r file | 從file中讀行 |
t label | if分支,從最後一行開始,條件一旦滿足或者T,t命令,將導致分支到帶有標號的命令處,或者到指令碼的末尾 |
T label | 錯誤分支,從最後一行開始,一旦發生錯誤或者T,t命令,將導致分支到帶有標號的命令處,或者到指令碼的末尾 |
w file | 寫並追加模板塊到file末尾 |
W file | 寫並追加模板塊的第一行到file末尾 |
! | 表示後面的命令對所有沒有被選定的行發生作用 |
= | 列印當前行號 |
# | 把註釋擴充套件到下一個換行符以前 |
標記 | 作用 |
---|---|
g | 表示行內全面替換 |
p | 表示列印行 |
w | 表示把行寫入一個檔案 |
x | 表示互換模板塊中的文字和緩衝區中的文字 |
y | 表示把一個字元翻譯為另外的字元(但是不用於正則表示式) |
\1 | 子串匹配標記 |
& | 已匹配字串標記 |
字符集 | 作用 |
---|---|
^ | 匹配行開始,如:/^sed/匹配所有以sed開頭的行 |
$ | 匹配行結束,如:/sed$/匹配所有以sed結尾的行 |
. | 匹配一個非換行符的任意字元,如:/s.d/匹配s後接一個任意字元,最後是d |
* | 匹配0個或多個字元,如:/*sed/匹配所有模板是一個或多個空格後緊跟sed的行 |
[] | 匹配一個指定範圍內的字元,如/[ss]ed/匹配sed和Sed |
[^] | 匹配一個不在指定範圍內的字元,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一個字母開頭,緊跟ed的行 |
(..) | 匹配子串,儲存匹配的字元,如s/(love)able/\1rs,loveable被替換成lovers |
& | 儲存搜尋字元用來替換其他字元,如s/love/&/,love這成love |
< | 匹配單詞的開始,如:/\ |
x{m} | 重複字元x,m次,如:/0{5}/匹配包含5個0的行 |
x{m,} | 重複字元x,至少m次,如:/0{5,}/匹配至少有5個0的行 |
x{m,n} | 重複字元x,至少m次,不多於n次,如:/0{5,10}/匹配5~10個0的行 |
實際應用
替換
sed 's/frost/frosts' forst.txt
細節決定成敗!
個人愚見,如有不對,懇請扶正!