本篇內(nèi)容主要講解“Linux系統(tǒng)中sed命令的使用介紹”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“Linux系統(tǒng)中sed命令的使用介紹”吧!
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:空間域名、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、祿豐網(wǎng)站維護(hù)、網(wǎng)站推廣。sed是linux輕量級流編輯器,用于行的操作,主要用來數(shù)據(jù)的選取、替換、刪除、新增等。從輸入文件中一次一行的讀取,
按順序?qū)⒘斜碇械拿顟?yīng)用到每一行,并將其編輯過的行,寫到標(biāo)準(zhǔn)輸出。
權(quán) 限:所有用戶
位 置:/bin/sed
用 法:sed [-nefr] [動作] file
參數(shù):
-n
不加-n的時候,sed處理的數(shù)據(jù)和不處理的都會輸出,加上-n只會輸出sed操作的行,
注意:與動作p和起來用,不要與其他動作一起用
-e
直接在命令行模式上進(jìn)行sed的動作編輯
例如:sed -e 's/aaa/b/g; s/aa/b/g' file也即多個動作同時操作,注意中間的分號
-f
直接將sed動作寫在一個文件內(nèi),-f file 則可以執(zhí)行filename內(nèi)的sed動作
-r
sed的動作支持?jǐn)U展的正則表達(dá)式(默認(rèn)支持基礎(chǔ)正則表達(dá)式)
-i
直接修改讀取的文件內(nèi)容
注意:多個選項參數(shù)一起用的時候,例如:sed -i -r ... 不可以這樣:sed -ir ...
動作說明:[n1[,n2]] function
不見得會存在,一般代表選擇動作的行數(shù),如果動作是在5到15行之間進(jìn)行替換,則"10,20c"
a 新增,當(dāng)前行的下一行
sed '2a hello world' file 輸出在第2行之后插入hello world
sed '2a hello world\
my name is csdn' file
輸出在2行下面插入兩行分別為hello world 和my name is scdn
特別注意hello world 后面的"\"
c 替換,是整行替換
sed '3,6c hello csdn' file
輸出把3至6行的只替換為 hello csdn(第3至6行只剩下一行hello csdn,不是3至6行的每一行都為hello csdn)
d 刪除
sed '3,6d' file 輸出刪除file的3至6行之后的內(nèi)容
i 插入,當(dāng)前行的上一行
與a動作類似,參照a動作用法
p 打印
sed -n '2,5p' file 打印file的第2至5行
s 替換
sed 's/oldString/newString/g' file oldString和newString支持基礎(chǔ)正則表達(dá)式和擴(kuò)展的正則表達(dá)式
cat -n nginx | sed '1,99s/[0-9]\{1,\}\.[0-9]\{1,\}\.[0-9]\{1,\}\.[0-9]\{1,\}//g' 把nginx日志的1至99行的第一個字段IP地址替換為空
結(jié)果為:
91 - - [15/Dec/2014:23:00:10 +0800],GET /identified?key=this-is-TMP-apikey&digest=914EBB2FD551844CBE15513C0126E6EE&digest-algorithm=ed2k&hash=9D37BB2988F26973371FAB028FEEEB93D5542300& HTTP/1.1,200 65,-,XMP Windows Client 4.9,-,ed2k://|file|ki141213.wmv|1119747351|914EBB2FD551844CBE15513C0126E6EE|h,00E04C377725NG4E,ki141213.wmv,1119747351 92 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,- 93 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,- 94 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,- 95 - - [15/Dec/2014:23:00:10 +0800],-,400 0,-,-,-,-,-,-,- 96 - - [15/Dec/2014:23:00:10 +0800],GET /identified?key=this-is-TMP-apikey&digest=76BB7C854168DCD1BF15FCB92E4114FFD4CFE7DE&digest-algorithm=magnet&hash=28003498535& HTTP/1.1,200 65,-,Thunder Windows Client 7.9,-,magnet:?xt=urn:btih:76BB7C854168DCD1BF15FCB92E4114FFD4CFE7DE,EC55F9E92A5212LQ,ABP-209R,1067178826 97 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,- 98 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,- 99 - - [15/Dec/2014:23:00:10 +0800],-,400 0,-,-,-,-,-,-,- 100 121.12.57.154 - - [15/Dec/2014:23:00:10 +0800],GET /identified? HTTP/1.1,401 112,-,-,-,-,-,-,-
動作其他用法1:sed '/模式/動作' 文件
可以指定某種模式的行進(jìn)行動作操作,如下(這里的文件名是a,注意cat a的輸出):
1、以p開頭的行前加[TAB]
$ cat a pa:11:a sa:32:c app:5:b stort:1:d pear:4:aa hello:3:f $ sed '/^p/s/^/\t/' a pa:11:a sa:32:c app:5:b stort:1:d pear:4:aa hello:3:f
2、刪除以a開頭的行,(那么下面的輸出,以a開頭的行就沒了)
$ sed '/^a/d' a pa:11:a sa:32:c stort:1:d pear:4:aa hello:3:f
3、反向匹配(文件a中,輸出只保留了a開頭的行)
$ sed '/^a/!d' a app:5:b
4、等價與grep -v (輸出文件a中,非p字母開頭的行)
$ grep -v '^h' a pa:11:a sa:32:c app:5:b stort:1:d pear:4:aa $ sed -n '/^h/!p' a pa:11:a sa:32:c app:5:b stort:1:d pear:4:aa
動作其他用法2:
也可以使用成對的正則表達(dá)式或行號與正則表達(dá)式的結(jié)合,來選取一定范圍的行,如下:
1、sed '1,3d' file 刪除1至3行
2、sed -n '1,3p' file 打印1至3行
3、sed '1, /^$/d' file 刪除范圍:第一行至第一個空行 (注意格式)
4、sed '/^$/, /^app/d' file 刪除范圍:第一個空行至以app開頭的行
5、sed '$d' file 刪除最后一行
注意:反向匹配行,是動作前加感嘆號 (!d !s !c等等)
如果前面的命令直接加入-i,則直接修改文件
到此,相信大家對“Linux系統(tǒng)中sed命令的使用介紹”有了更深的了解,不妨來實際操作一番吧!這里是創(chuàng)新互聯(lián)建站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!