sed是一個管道命令,能夠將數據進行替換、刪除、新增、選取特定行等功能正則表達式
-e<script>或--expression=<script>:以選項中的指定的script來處理輸入的文本文件;
-f<script文件>或--file=<script文件>:以選項中指定的script文件來處理輸入的文本文件;
-h或--help:顯示幫助; -n或--quiet或——silent:僅顯示script處理後的結果; -V或--version:顯示版本信息。
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**。 \< 匹配單詞的開始,如:/\<love/匹配包含以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的行。
s命令能夠將文件a中的Line改爲row
使用後綴 /g 標記會替換每一行中的全部匹配

-n選項和p命令一塊兒使用表示只打印那些發生替換的行

選項-i 能夠對原文件也進行修改

當須要從第N處匹配開始替換時,能夠使用 /Ng:express
echo sksksksksksk | sed 's/sk/SK/2g'
skSKSKSKSKSK
echo sksksksksksk | sed 's/sk/SK/3g'
skskSKSKSKSK
echo sksksksksksk | sed 's/sk/SK/4g'
skskskSKSKSK
刪除第4行到最後一行ui
刪除空白行spa
刪除文件中全部開頭是test的行:翻譯
sed '/^test/'d file
打印奇數行3d
打印偶數行blog
打印第3行ip
打印第3到5行內存