linux shell的sed命令詳解(2)
linux shell的sed命令詳解
補(bǔ)充:linux shell的sed常用命令
這是對(duì)sed命令與選項(xiàng)的一個(gè)比較全面的補(bǔ)充,主要是從網(wǎng)上搜集的例子。
1 p命令
命令p用于顯示模式空間的內(nèi)容。默認(rèn)情況下,sed把輸入行打印在屏幕上,選項(xiàng)-n用于取消默認(rèn)的打印操作。當(dāng)選項(xiàng)-n和命令p同時(shí)出現(xiàn)時(shí),sed可打印選定的內(nèi)容。
復(fù)制代碼代碼如下:
sed '/my/p' datafile
#默認(rèn)情況下,sed把所有輸入行都打印在標(biāo)準(zhǔn)輸出上。如果某行匹配模式my,p命令將把該行另外打印一遍。
sed -n '/my/p' datafile
#選項(xiàng)-n取消sed默認(rèn)的打印,p命令把匹配模式my的行打印一遍。
2.d命令
命令d用于刪除輸入行。sed先將輸入行從文件復(fù)制到模式空間里,然后對(duì)該行執(zhí)行sed命令,最后將模式空間里的內(nèi)容顯示在屏幕上。如果發(fā)出的是命令d,當(dāng)前模式空間里的輸入行會(huì)被刪除,不被顯示。
sed '$d' datafile
#刪除最后一行,其余的都被顯示
sed '/my/d' datafile
#刪除包含my的行,其余的都被顯示
3.s命令
sed 's/^My/You/g' datafile
#命令末端的g表示在行內(nèi)進(jìn)行全局替換,也就是說如果某行出現(xiàn)多個(gè)My,所有的My都被替換為You。
sed -n '1,20s/My$/You/gp' datafile
#取消默認(rèn)輸出,處理1到20行里匹配以My結(jié)尾的行,把行內(nèi)所有的My替換為You,并打印到屏幕上。
sed 's#My#Your#g' datafile
#緊跟在s命令后的字符就是查找串和替換串之間的分隔符。分隔符默認(rèn)為正斜杠,但可以改變。無論什么字符(換行符、反斜線除外),只要緊跟s命令,就成了新的串分隔符。
4 e選項(xiàng)
-e是編輯命令,用于sed執(zhí)行多個(gè)編輯任務(wù)的情況下。在下一行開始編輯前,所有的編輯動(dòng)作將應(yīng)用到模式緩沖區(qū)中的行上。
sed -e '1,10d'-e 's/My/Your/g' datafile
#選項(xiàng)-e用于進(jìn)行多重編輯。第一重編輯刪除第1-3行。第二重編輯將出現(xiàn)的所有My替換為Your。因?yàn)槭侵鹦羞M(jìn)行這兩項(xiàng)編輯(即這兩個(gè)命令都在模式空間的當(dāng)前行上執(zhí)行),所以編輯命令的順序會(huì)影響結(jié)果。
5 r命令
r命令是讀命令。sed使用該命令將一個(gè)文本文件中的內(nèi)容加到當(dāng)前文件的特定位置上。
sed '/My/r introduce.txt' datafile
#如果在文件datafile的某一行匹配到模式My,就在該行后讀入文件introduce.txt的內(nèi)容。如果出現(xiàn)My的行不止一行,則在出現(xiàn)My的各行后都讀入introduce.txt文件的內(nèi)容。
6 w命令
sed -n '/hrwang/w me.txt' datafile
7 a\ 命令
a\ 命令是追加命令,追加將添加新文本到文件中當(dāng)前行(即讀入模式緩沖區(qū)中的行)的后面。所追加的文本行位于sed命令的下方另起一行。如果要追加的內(nèi)容超過一行,則每一行都必須以反斜線結(jié)束,最后一行除外。最后一行將以引號(hào)和文件名結(jié)束。
sed '/^hrwang/a\
>hrwang and mjfan are husband\
>and wife' datafile
#如果在datafile文件中發(fā)現(xiàn)匹配以hrwang開頭的行,則在該行下面追加hrwang and mjfan are husband and wife
8 i\ 命令
i\ 命令是在當(dāng)前行的前面插入新的文本。
9 c\ 命令
sed使用該命令將已有文本修改成新的文本。
10 n命令
sed使用該命令獲取輸入文件的下一行,并將其讀入到模式緩沖區(qū)中,任何sed命令都將應(yīng)用到匹配行緊接著的下一行上
sed '/hrwang/{n;s/My/Your/;}' datafile
=注:如果需要使用多條命令,或者需要在某個(gè)地址范圍內(nèi)嵌套地址,就必須用花括號(hào)將命令括起來,每行只寫一條命令,或這用分號(hào)分割同一行中的多條命令。
11 y命令
該命令與UNIX/Linux中的tr命令類似,字符按照一對(duì)一的方式從左到右進(jìn)行轉(zhuǎn)換。例如,y/abc/ABC/將把所有小寫的a轉(zhuǎn)換成A,小寫的b轉(zhuǎn)換成B,小寫的c轉(zhuǎn)換成C。
sed '1,20y/hrwang12/HRWANG^$/' datafile
#將1到20行內(nèi),所有的小寫hrwang轉(zhuǎn)換成大寫,將1轉(zhuǎn)換成^,將2轉(zhuǎn)換成$。
#正則表達(dá)式元字符對(duì)y命令不起作用。與s命令的分隔符一樣,斜線可以被替換成其它的字符。
12 q命令
q命令將導(dǎo)致sed程序退出,不再進(jìn)行其它的處理
01.sed '/hrwang/{s/hrwang/HRWANG/;q;}' datafile
13 h命令和g命令
#cat datafile
My name is hrwang.
Your name is mjfan.
hrwang is mjfan's husband.
mjfan is hrwang's wife.
sed -e '/hrwang/h'-e '$G' datafile
sed -e '/hrwang/H' -e '$G' datafile
#通過上面兩條命令,你會(huì)發(fā)現(xiàn)h會(huì)把原來暫存緩沖區(qū)的內(nèi)容清除,只保存最近一次執(zhí)行h時(shí)保存進(jìn)去的模式空間的內(nèi)容。而H命令則把每次匹配hrwnag的行都追加保存在暫存緩沖區(qū)。
sed -e '/hrwang/H' -e '$g' datafile
sed -e '/hrwang/H' -e '$G' datafile
#通過上面兩條命令,你會(huì)發(fā)現(xiàn)g把暫存緩沖區(qū)中的內(nèi)容替換掉了模式空間中當(dāng)前行的內(nèi)容,此處即替換了最后一行。而G命令則把暫存緩沖區(qū)的內(nèi)容追加到了模式空間的當(dāng)前行后。此處即追加到了末尾