例如,在多個系統(tǒng)、應(yīng)用程序安裝之后,我們往往需要對很多配置文件進行修改,用vi編輯器意味著耗費時間、重復(fù)勞動,而sed就可將我們從繁重的重復(fù)勞動中解放出來。
sed的調(diào)用方式:
1、sed [sed選項] 'sed命令' 要修改的文件
2、sed [sed選項] -f sed腳本 要修改的文件
3、sed腳本 [sed選項] 要修改的文件
這里僅介紹最常用的第一種方式
sed選項:僅列常用的
-i:直接修改源文件(不用這個選項的話無法直接修改,必須重定向到新文件,如果僅作為輸出測試則不需此選項),還可將源文件修改前備份
sed -i.bak 's/123/234/' test.txt 將test.txt備份為test.txt.bak,然后將文件內(nèi)行第一個出現(xiàn)的“123”替換為“234”
-e:多次編輯,例如先將所有的123替換為234,再將第7行前加#號注釋
sed -i -e 's/123/234/g' -i -e '7 s/^/#/' test.txt
-f:指定sed腳本文件名
-n:取消默認的輸出(不打?。?,用sed不加任何選項的話你會看到所有內(nèi)容輸出,并不是按照sed命令所限制的條件輸出,那么配合“p”命令經(jīng)可以過濾掉不符合條件的行,并顯示出符合條件的行,例如
sed -n '查找所有包含字符123的行'p test.txt 或 sed -n '查找所有包含字符123的行p' test.txt
sed命令:這里可以使用正則表達式,如遇特殊字符,需用“\”來屏蔽其特殊含義,例如“\$”表示普通的字符$
x x為某行行號
x,y 例如2,5,從第2行到第5行
/val/ 查詢包含“val”字符的行
/val1/val2/ 查詢包含兩個模式的行
val/,x 在給定行號的行上查詢包含“val”的行
x,/val/ 通過行號和模式查詢匹配的行
x,y! 不包含指定行號x,y的行
p 打印匹配的行
= 顯示行號
a\ 在定位了的行之后附加內(nèi)容
i\ 在定位了的行之后插入內(nèi)容
d 刪除定位的行,例如:2d 代表刪除第2行
c\ 用新文本替換定位行的文本
s 替換,形式為:'s/查找的內(nèi)容/替換的內(nèi)容/'
g 進行全局替換,如不使用此選項將只對該行匹配到的第一個結(jié)果進行替換,該行下一個匹配的就不處理了。
...其他就不介紹了,百度搜下吧
實例學(xué)習(xí):
test.txt文件內(nèi)容為
The honeysuckle band played all night long for only $90
It was an evening of splendid music and company
Too bad the disco floor fell through at 23:10
The local nurse Miss P.Neave was in attendance
1、顯示第2行的內(nèi)容
sed -n '2p' test.txt
2、顯示第1到3行的內(nèi)容
sed -n '1,3'p test.txt
3、僅顯示包含“disco”的行
sed -n '/disco/'p test.txt
4、顯示包含“$”字符的行
sed -n '/\$/'p test.txt
5、顯示以數(shù)字結(jié)尾的行,[0-9]是正則表達式 代表數(shù)字0到9;“$”表示行尾(“^”表示行首)
sed -n '/[0-9]$/'p test.txt
顯示結(jié)果為:
The honeysuckle band played all night long for only $90
Too bad the disco floor fell through at 23:10
6、顯示以數(shù)字結(jié)尾的行并顯示以大寫T為開頭的行
sed -n -e '/^T/'p -e '/[0-9]$/'p test.txt
7、匹配任意字母、后跟任意字母的多次重復(fù),并以“ing”結(jié)尾的行
sed -n '/.*ing/'p test.txt
8、第一行與最后一行
sed -n '1p' test.txt
sed -n '$p' test.txt
9、將“nurse”改為“l(fā)ittle nurse”,“”命令用來重新調(diào)用被替換的內(nèi)容
sed -n 's/nurse/little /p' test.txt
10、先將所有的123替換為234,再將第7行前加#號注釋
sed -i -e 's/123/234/g' -i -e '7 s/^/#/' test.txt
11、將“--------”刪除,將空行刪除,將第一行和最后一行刪除,并打印第一列
文件內(nèi)容:
Database Size(MB) Date Created
------------------------------------------
mysql 2244 12/11/08
test 5632 12/11/08
(2 rows affected)
命令:
cat test.txt | sed 's/--*//g' | sed '/^$/d' | sed '$d' | sed '1d' | awk '{print $1}'
顯示結(jié)果:
mysql
test
說明:
使用s/--*//g刪除橫線-------
使用/^$/d刪除空行
使用$d刪除最后一行
使用1d刪除第一行
awk {print $1}打印第一列
12、一些雜項例子
^[0-9]表示行第一個字符為任意數(shù)字,例如“1asdf”;
^[0-9]*表示行首包含任意個數(shù)的數(shù)字,例如“1818asdf”
[0-9][0-9]*$表示行尾包含至少2個數(shù)字,例如“asdfasdf18”“asdf1818”
sed -i 's/^[0-9]*//g' test.txt 刪除行首的任意數(shù)字
sed -i -e 's/^[0-9]*//g' -i -e 's/$/ passed/' test.txt 刪除行首任意數(shù)字,并在每行結(jié)尾加上“ passed”
sed -i -e 's/^/#' test.txt 給每行行首加上“#”注釋
s/\.$//g 刪除以句點結(jié)尾的行的句點
s/^[ ][ ]*// 刪除行首的任意個空格
s/^.// 刪除行首的第一個字符
s/^\/// 刪除行首的“/”字符
s/SP\(..\)//g 刪除字符“SP”以及緊跟其后的兩個任意字符,“SPLLY”-->“Y”