sed是一個(gè)很好的文件處理工具,本身是一個(gè)管道命令,主要是以行為單位進(jìn)行處理,將數(shù)據(jù)行進(jìn)行替換踩身、刪除稍浆、新增、選取等试和。
- -help 查看sed的用法
- -n, --quiet, --silent suppress automatic printing of pattern space
阻止默認(rèn)輸出(顯示)模版空間里的數(shù)據(jù)讯泣,此時(shí)只輸出p命令指定的內(nèi)容。 - -e script, --expression=script add the script to the commands to be executed
將指定腳本SCRIPT中的命令增加到處理輸入文件的命令組中 - -f script-file, --file=script-file add the contents of script-file to the commands to be executed
將指定腳本SCRIPT-FILE中的命令增加到處理輸入文件的命令組中阅悍。 - --follow-symlinks follow symlinks when processing in place
只在支持符號(hào)連接的系統(tǒng)中好渠,并且同時(shí)用選項(xiàng)-i時(shí)才有作用:若指定的輸入文件是一個(gè)符號(hào)連接,SED會(huì)處理符號(hào)連接的目標(biāo)文件节视,并保持連接拳锚。默認(rèn)SED會(huì)斷開連接,使符號(hào)連接的目標(biāo)文件不會(huì)被修改寻行。 - -i[SUFFIX], --in-place[=SUFFIX] edit files in place (makes backup if SUFFIX supplied)
將文件放在in-place里編輯處理霍掺。GNU是通過(guò)創(chuàng)建一個(gè)臨時(shí)文件,并將SED的輸出送到此文件拌蜘,而不是送到標(biāo)準(zhǔn)輸出的方式來(lái)實(shí)現(xiàn)杆烁。應(yīng)用于命令:=、a简卧、c兔魂、i、l举娩、p中析校,但同時(shí)還可用命令w或W及將輸出文件指定為/dev/stdout构罗,實(shí)現(xiàn)SED的輸出也同時(shí)送到標(biāo)準(zhǔn)輸出。
此選項(xiàng)已隱含了另一選項(xiàng)-s勺良。i與SUFFIX之間不能有空格
一個(gè)文件處理完時(shí)绰播,SED將創(chuàng)建的臨時(shí)文件名換成輸出文件的原名(即被處理的輸入文件名)。若指定有后綴SUFFIX尚困,則會(huì)先將舊文件換名成SUFFIX后綴而形成備份蠢箩;否則舊文件被覆蓋而無(wú)備份。
換名規(guī)則是:若SUFFIX不含有星號(hào)(),將SUFFIX作為后綴直接追加在舊文件名后事甜;否則谬泌,SUFFIX中的每個(gè)星號(hào)()都被舊文件名取代。好處是:還允許為備份文件指定前綴逻谦,而不僅僅是后綴掌实,甚至將可備份放到另一個(gè)目錄中(目錄必須已存在) - -l N, --line-length=N specify the desired line-wrap length for the `l' command --posix disable all GNU extensions.
指定l(L)命令自動(dòng)換行的長(zhǎng)度為N,0表示不對(duì)長(zhǎng)行進(jìn)行自動(dòng)換行處理邦马,默認(rèn)是70贱鼻。 - -r, --regexp-extended use extended regular expressions in the script.
用擴(kuò)展正則表達(dá)式規(guī)則來(lái)解釋匹配模版。 - -s, --separate consider files as separate rather than as a single continuous long stream.
默認(rèn)SED將命令行上指定的多個(gè)輸入文件看作成一個(gè)連續(xù)的長(zhǎng)數(shù)據(jù)流處理滋将。用這個(gè)GNU的擴(kuò)展選項(xiàng)邻悬,SED將會(huì)看作各個(gè)獨(dú)立的文件來(lái)處理,
但注意的是:指定的地址范圍不能跨度到其他文件随闽;顯示的行號(hào)都是相對(duì)于各自文件的首行父丰;字符$會(huì)指示每個(gè)文件的最后一行;來(lái)自R命令的調(diào)用文件對(duì)每個(gè)輸入文件都會(huì)重新執(zhí)行一次掘宪。 - -u, --unbuffered load minimal amounts of data from the input files and flush the output buffers more often
對(duì)輸入和輸出都根據(jù)實(shí)際蛾扇,盡可能小地進(jìn)行緩沖處理,或不緩沖魏滚。這對(duì)SED命令的輸入是來(lái)自類似于命令tail –f镀首,而你又想盡可能快地看到處理后的輸出,是特別有用的鼠次。 - -z, --null-data separate lines by NUL characters
--help display this help and exit
顯示sed參數(shù)信息后退出蘑斧。
--version output version information and exit
顯示sed版本信息后退出。
# 截取第五行的數(shù)據(jù):
sed -n '5p' /etc/passwd
# 多個(gè)空格替換成一個(gè)空格:
sed 's/\ */\ /g' test.txt
# 刪除man后面的數(shù)據(jù):
# root@ubuntu:/home/jianeng# head /etc/passwd
# root:x:0:0:root:/root:/bin/bash
# daemon:x:1:1:daemon:/usr/sbin:/usr/sbin/nologin
# man:x:6:12:man:/var/cache/man:/usr/sbin/nologin
# man:.* 意思是: 這個(gè)字符后的所有字符
# a.*b须眷,它將會(huì)匹配最長(zhǎng)的以a開始竖瘾,以b結(jié)束的字符串
head /etc/passwd | grep 'man:' | sed 's/:.*//g'