|
只顯示指定行范圍的文件內容,例如:
sed -n '100,200p' mysql_slow_query.log
地址是逗號分隔的,那么需要處理的地址是這兩行之間的范圍(包括這兩行在內)。范圍可以用數字、正則表達式、或二者的組合表示。例如:
|
sed命令告訴sed如何處理由地址指定的各輸入行,如果沒有指定地址則處理所有的輸入行。
3.1 sed命令
命令 | 功能 |
a\ | 在當前行后添加一行或多行。多行時除最后一行外,每行末尾需用“\”續行 |
c\ | 用此符號后的新文本替換當前行中的文本。多行時除最后一行外,每行末尾需用"\"續行 |
i\ | 在當前行之前插入文本。多行時除最后一行外,每行末尾需用"\"續行 |
d | 刪除行 |
h | 把模式空間里的內容復制到暫存緩沖區 |
H | 把模式空間里的內容追加到暫存緩沖區 |
g | 把暫存緩沖區里的內容復制到模式空間,覆蓋原有的內容 |
G | 把暫存緩沖區的內容追加到模式空間里,追加在原有內容的后面 |
l | 列出非打印字符 |
p | 打印行 |
n | 讀入下一輸入行,並從下一條命令而不是第一條命令開始對其的處理 |
q | 結束或退出sed |
r | 從文件中讀取輸入行 |
! | 對所選行以外的所有行應用命令 |
s | 用一個字符串替換另一個 |
g | 在行內進行全局替換 |
w | 將所選的行寫入文件 |
x | 交換暫存緩沖區與模式空間的內容 |
y | 將字符替換為另一字符(不能對正則表達式使用y命令) |
3.2 sed選項
選項 | 功能 |
-e | 進行多項編輯,即對輸入行應用多條sed命令時使用 |
-n | 取消默認的輸出 |
-f | 指定sed腳本的文件名 |
元字符 | 功能 | 示例 |
^ | 行首定位符 | /^my/ 匹配所有以my開頭的行 |
$ | 行尾定位符 | /my$/ 匹配所有以my結尾的行 |
. | 匹配除換行符以外的單個字符 | /m..y/ 匹配包含字母m,后跟兩個任意字符,再跟字母y的行 |
* | 匹配零個或多個前導字符 | /my*/ 匹配包含字母m,后跟零個或多個y字母的行 |
[] | 匹配指定字符組內的任一字符 | /[Mm]y/ 匹配包含My或my的行 |
[^] | 匹配不在指定字符組內的任一字符 | /[^Mm]y/ 匹配包含y,但y之前的那個字符不是M或m的行 |
\(..\) | 保存已匹配的字符 | 1,20s/\(you\)self/\1r/ 標記元字符之間的模式,並將其保存為標簽1,之后可以使用\1來引用它。最多可以定義9個標簽,從左邊開始編號,最左邊的是第一個。此例中,對第1到第20行進行處理,you被保存為標簽1,如果發現youself,則替換為your。 |
& | 保存查找串以便在替換串中引用 | s/my/**&**/ 符號&代表查找串。my將被替換為**my** |
\< | 詞首定位符 | /\<my/ 匹配包含以my開頭的單詞的行 |
\> | 詞尾定位符 | /my\>/ 匹配包含以my結尾的單詞的行 |
x\{m\} | 連續m個x | /9\{5\}/ 匹配包含連續5個9的行 |
x\{m,\} | 至少m個x | /9\{5,\}/ 匹配包含至少連續5個9的行 |
x\{m,n\} | 至少m個,但不超過n個x | /9\{5,7\}/ 匹配包含連續5到7個9的行 |
|
6.2 d命令
命令d用於刪除輸入行。sed先將輸入行從文件復制到模式空間里,然后對該行執行sed命令,最后將模式空間里的內容顯示在屏幕上。如果發出的是命令d,當前模式空間里的輸入行會被刪除,不被顯示。
|
6.3 s命令
|
|
6.4 e選項
-e是編輯命令,用於sed執行多個編輯任務的情況下。在下一行開始編輯前,所有的編輯動作將應用到模式緩沖區中的行上。
|
6.5 r命令
r命令是讀命令。sed使用該命令將一個文本文件中的內容加到當前文件的特定位置上。
|
|
6.7 a\ 命令
a\ 命令是追加命令,追加將添加新文本到文件中當前行(即讀入模式緩沖區中的行)的后面。所追加的文本行位於sed命令的下方另起一行。如果要追加的內容超過一行,則每一行都必須以反斜線結束,最后一行除外。最后一行將以引號和文件名結束。
|
6.8 i\ 命令
i\ 命令是在當前行的前面插入新的文本。
6.9 c\ 命令
sed使用該命令將已有文本修改成新的文本。
6.10 n命令
sed使用該命令獲取輸入文件的下一行,並將其讀入到模式緩沖區中,任何sed命令都將應用到匹配行緊接着的下一行上。
|
|
6.12 q命令
q命令將導致sed程序退出,不再進行其它的處理。
|
6.13 h命令和g命令
|
1.sed -n '2'p filename
打印文件的第二行。
2.sed -n '1,3'p filename
打印文件的1到3行
3. sed -n '/Neave/'p filename
打印匹配Neave的行(模糊匹配)
4. sed -n '4,/The/'p filename
在第4行查詢模式The
5. sed -n '1,$'p filename
打印整個文件,$表示最后一行。
6. sed -n '/.*ing/'p filename
匹配任意字母,並以ing結尾的單詞(點號不能少)
7 sed -n / -e '/music/'= filename
打印匹配行的行號,-e 會打印文件的內容,同時在匹配行的前面標志行號。-n只打印出實際的行號。
8.sed -n -e '/music/'p -e '/music/'= filename
打印匹配的行和行號,行號在內容的下面
9.sed '/company/' a\ "Then suddenly it happend" filename
選擇含有company的行,將后面的內容"Then suddenly it happend"加入下一行。注意:它並不改變文件,所有操作在緩沖區,如果要保存輸出,重定向到一個文件。
10. sed '/company/' i\ "Then suddenly it happend" filename
同9,只是在匹配的行前插入
11.sed '/company/' c\ "Then suddenly it happend" filename
用"Then suddenly it happend"替換匹配company的行的內容。
12.sed '1'd ( '1,3'd '$'d '/Neave/'d) filename
刪除第一行(1到3行,最后一行,匹配Neave的行)
13.[ address [,address]] s/ pattern-to-find /replacement-pattern/[g p w n]
s選項通知s e d這是一個替換操作,並查詢pattern-to-find,成功后用replacement-pattern替換它。
替換選項如下:
g 缺省情況下只替換第一次出現模式,使用g選項替換全局所有出現模式。
p 缺省s e d將所有被替換行寫入標准輸出,加p選項將使- n選項無效。- n選項不打印輸出結果。
w 文件名使用此選項將輸出定向到一個文件。(注意只將匹配替換的行寫入文件,而不是整個內容)
14.sed s'/nurse/"hello "&/' filename
將'hello '增加到'nurse' 的前面。
15. sed '/company/r append.txt' filename
在匹配company的行的下一行開始加入文件append.txt的內容。
16. sed '/company/'q filename
首次匹配company后就退出sed程序
sed '1,3d' file //刪除1-3行
sed '/[Aa]bc/p' file //打印包含Abc或者abc的行
sed '/ABC/d' //刪除包含ABC的行
sed '/ABC/!d' //不刪除包含ABC的行
sed '5,$d' //從第五行到最后一行全部刪除
sed 1q //顯示第一行
sed 's/$/.../g' //每行的最后面添加 ...
sed 's/d.(sk)/1&/g' //滿足d*sk的單詞,在單詞前添加sk
sed 's/<[^>]*>//g' //去除html標簽
sed '/ABC/a123' //在包含ABC的行后面添加一行數值為123的行
sed '/ABC/i123' //跟a不同的是i是插入當前行的前面
sed '/ABC/c123' //包含ABC的行將更改為123
sed '/ABC/{n;s/123/ABC/g}' //精確匹配包含ABC的下一行,將123全部替換成ABC
sed '/ABC/{s/A/a/}' //在包含ABC的行將A替換成a
sed -e '/ABC/h' -e '$g' //將包含ABC的行復制,在最后一行添加.
sed -e '/ABC/{h;d}' -e '/123/G' //將包含ABC的行復制並刪除,在包含123的行后添加.
g等於在當前行覆蓋,G是在符合條件的行后新增加一行.
sed 's/^/ /g' //每行前面增加一個空格
sed 's/.(.)$/*1/' //將倒數第二位換成*
sed '/ABC/!s/1/*/g' //在不包含ABC的行里,將所有的1替換成*
sed 's/1|2|3/*/g' //在GNU里將不管是1或2或者是3替換成*
sed -i '20,30d' filename 刪除第20-30行
sed腳本就是寫在文件中的一列sed命令。腳本中,要求命令的末尾不能有任何多余的空格或文本。如果在一行中有多個命令,要用分號分隔。執行腳本時,sed先將輸入文件中第一行復制到模式緩沖區,然后對其執行腳本中所有的命令。每一行處理完畢后,sed再復制文件中下一行到模式緩沖區,對其執行腳本中所有命令。使用sed腳本時,不再用引號來確保sed命令不被shell解釋。例如sed腳本script:
|
|