Sed簡介
一、簡介
sed全稱是:Stream EDitor。sed命令的功能同awk類似,差別在于,sed簡單,對列處理的功能要差一些,awk的功能復雜,對列處理的功能比較強大。
sed 是一種在線編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩沖區中,稱為“模式空間”(pattern space),接著用sed命令處理緩沖區中的內容,處理完成后,把緩沖區的內容送往屏幕。接著處理下一行,這樣不斷重復,直到文件末尾。文件內容并沒有 改變,除非你使用重定向存儲輸出。Sed主要用來自動編輯一個或多個文件;簡化對文件的反復操作;編寫轉換程序等。
二、sed語法格式
sed [options] 'command' file(s)
sed [options] -f scriptfile file(s)
三、命令與選項
sed命令告訴sed如何處理由地址指定的各輸入行,如果沒有指定地址則處理所有的輸入行。
1、 sed命令
命令 |
功能 |
a\ |
在當前行后添加一行或多行。多行時除最后一行外,每行末尾需用“\”續行 |
c\ |
用此符號后的新文本替換當前行中的文本。多行時除最后一行外,每行末尾需用"\"續行 |
i\ |
在當前行之前插入文本。多行時除最后一行外,每行末尾需用"\"續行 |
d |
刪除行 |
h |
把模式空間里的內容復制到暫存緩沖區 |
H |
把模式空間里的內容追加到暫存緩沖區 |
g |
把暫存緩沖區里的內容復制到模式空間,覆蓋原有的內容 |
G |
把暫存緩沖區的內容追加到模式空間里,追加在原有內容的后面 |
l |
列出非打印字符 |
p |
打印行 |
n |
讀入下一輸入行,并從下一條命令而不是第一條命令開始對其的處理 |
q |
結束或退出sed |
r |
從文件中讀取輸入行 |
! |
對所選行以外的所有行應用命令 |
s |
用一個字符串替換另一個 |
g |
在行內進行全局替換 |
w |
將所選的行寫入文件 |
x |
交換暫存緩沖區與模式空間的內容 |
y |
將字符替換為另一字符(不能對正則表達式使用y命令) |
2、 sed選項
選項 |
功能 |
-e |
進行多項編輯,即對輸入行應用多條sed命令時使用 |
-n |
取消默認的輸出 |
-f |
指定sed腳本的文件名 |
四、正則表達式元字符
與grep一樣,sed也支持特殊元字符,來進行模式查找、替換。不同的是,sed使用的正則表達式是括在斜杠線"/"之間的模式。
如果要把正則表達式分隔符"/"改為另一個字符,比如o,只要在這個字符前加一個反斜線,在字符后跟上正則表達式,再跟上這個字符即可。例如:sed -n '\o^Myop' datafile
元字符 |
功能 |
示例 |
^ |
行首定位符 |
/^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的行 |
五、實例分析
1、刪除:d命令
$ sed '2d' example—–刪除example文件的第二行。 實例操作:sed '2d' /etc/issue
$ sed '2,$d' example—–刪除example文件的第二行到末尾所有行。實例操作:sed '2,$d' /etc/issue
$ sed '$d' example—–刪除example文件的最后一行。實例操作:sed '$d' /etc/issue
$ sed '/test/'d example—–刪除example文件所有包含test的行。實例操作:sed '/Kernel/d' /etc/issue
2、替換:s命令
$ sed 's/test/mytest/g' example—–在整行范圍內把test替換為mytest。如果沒有g標記,則只有每行第一個匹配的test被替換成mytest。
實例操作:sed 's/UUID/test/g' /etc/fstab
實例操作:sed 's/proc/test/' /etc/fstab 此處沒有g標記,只替換每行一個匹配的proc為test
$ sed -n 's/^test/mytest/p' example—–(-n)選項和p標志一起使用表示只打印那些發生替換的行。也就是說,如果某一行開頭的test被替換成mytest,就打印它。
實例操作: sed -n 's/proc/test/p' /etc/fstab
$ sed 's/^192.168.0.1/&localhost/' example—–&;符號表示替換換字符串中被找到的部份。所有以192.168.0.1開頭的行都會被替換成它自已加localhost,變成192.168.0.1localhost。
實例操作: sed 's/^UUID/&localhost/' /etc/sysconfig/network-scripts/ifcfg-eth0 :將UUID替換為UUIDlocalhost
$ sed -n 's/\(love\)able/\1rs/p' example—–love被標記為1,所有loveable會被替換成lovers,而且替換的行會被打印出來。
實例操作:sed -n 's/\(Kernel\)/\1test/p' /etc/issue 此處將Kernel替換為Kerneltest
$ sed 's#10#100#g' example—–不論什么字符,緊跟著s命令的都被認為是新的分隔符,所以,“#”在這里是分隔符,代替了默認的“/”分隔符。表示把所有10替換成100。實例操作: sed 's#Kernel#1000Kernel#g' /etc/issue 將kernel替換為1000kernel
3、選定行的范圍:逗號$ sed -n '/test/,/check/p' example—–所有在模板test和check所確定的范圍內的行都被打印。
$ sed -n '5,/^test/p' example—–打印從第五行開始到第一個包含以test開始的行之間的所有行。
實例操作: sed -n '5,/^UUID/p' /etc/fstab
$ sed '/test/,/check/s/$/sed test/' example—–對于模板test和check之間的行,每行的末尾用字符串sed test替換。
實例操作: sed '/UUID/,/tmpfs/s/$/2015test/' /etc/fstab 將UUID和tmpfs之間的行,末尾加上2015test
4、多點編輯:e命令
$ sed -e '1,5d' -e 's/test/check/' example—–(-e)選項允許在同一行里執行多條命令。如例子所示,第一條命令刪除1至5行,第二條命令用check替換test。命令的執行順序對結果有影響。如果兩個命令都是替換命令,那么第一個替換命令將影響第二個替換命令的結果。
實例操作: sed -e '1,3d' -e 's/UUID/test/' /etc/fstab
$ sed –expression='s/test/check/' –expression='/love/d' example—–一個比-e更好的命令是–expression。它能給sed表達式賦值。
5、從文件讀入:r命令
$ sed '/test/r file' example—–file里的內容被讀進來,顯示在與test匹配的行后面,如果匹配多行,則file的內容將顯示在所有匹配行的下面。
實例操作: sed '/UUID/r /etc/issue' /etc/fstab
6、寫入文件:w命令
$ sed -n '/test/w file' example—–在example中所有包含test的行都被寫入file里。
此處文件file中的內容會被覆蓋?。?!
7、追加命令:a命令
$ sed '/^test/a\\—>this is a example' example<—–'this is a example'被追加到以test開頭的行后面,sed要求命令a后面有一個反斜杠。
8、插入:i命令
$ sed '/test/i\\ new line ————————-' example 如果test被匹配,則把反斜杠后面的文本插入到匹配行的前面。
9、下一個:n命令
$ sed '/test/{ n; s/aa/bb/; }' example—–如果test被匹配,則移動到匹配行的下一行,替換這一行的aa,變為bb,并打印該行,然后繼續。
10、變形:y命令
$ sed '1,10y/abcde/ABCDE/' example—–把1–10行內所有abcde轉變為大寫,注意,正則表達式元字符不能使用這個命令。
11、退出:q命令
$ sed '10q' example—–打印完10行后,退出sed。
12、保持和獲?。?/span>h命令和G命令
$ sed -e '/test/h' -e '$G' example—–在sed處理文件的時候,每一行都被保存在一個叫模式空間的臨時緩沖區中,除非行被刪除或者輸出被取消,否則所有被處理的行都將打印在屏幕上。接著模式空間被清空,并存入新的一行等待處理。在這個例子里,匹配test的行被找到后,將存入模式空間,h命令將其復制并存入一個稱為保持緩存區的特殊緩沖區內。第二條語句的意思是,當到達最后一行后,G命令取出保持緩沖區的行,然后把它放回模式空間中,且追加到現 在已經存在于模式空間中的行的末尾。在這個例子中就是追加到最后一行。簡單來說,任何包含test的行都被復制并追加到該文件的末尾。
13、保持和互換:h命令和x命令
$ sed -e '/test/h' -e '/check/x' example —–互換模式空間和保持緩沖區的內容。也就是把包含test與check的行互換。
原創文章,作者:wxdz_2004(古雨秋),如若轉載,請注明出處:http://www.www58058.com/4178