sed命令及vim的末行命令
sed:StreamEDitor,流編輯器,以行為單位對一個或多個文件進行編輯處理;每一次sed都會處理給定文件中的一行內容。
在sed處理文本時,將正在處理的當前行存儲到臨時的緩沖區中,稱為“模式空間”;用當前行去匹配給定的PATTERN,如果能匹配,則使用command編輯處理;如果不匹配,則默認輸出至標準輸出;然後繼續處理下一行,直到文件的末尾。
默認情況下,sed的所有處理行為不會影響源文件的內容;
我們一般會使用sed命令來自動編輯一個或多個文件,簡化對文件的循環操作;
sed命令:
sed - stream editor for filtering andtransforming text
sed [OPTION]... ‘script‘ [input-file]...
常用選項:
-n, --quiet, --silent:對於不能匹配模式的行,默認不輸出到屏幕;
-e script, --expression=script:多條件編輯;
-f script-file, --file=script-file:從指定的script-file中讀取腳本
註意:script-file為一個能夠定位到腳本文件的路徑,最好為絕對路徑
-i[SUFFIX], --in-place[=SUFFIX]
-r, --regexp-extended:使sed支持擴展正則表達式;
script:
‘AddressesCommand‘
Addresses(地址定界):
1.空地址:對所有文件的所有行進行處理;
2.單地址:sed對於能夠匹配該地址的那唯一一行進行處理;
num:表示行號;
/pattern/:能夠匹配該模式的所有行;
$
3.地址範圍:
addr1,addr2:從addr1開始到addr2結束的中間所有行;
例如:2,8
first~step:從first標記的行號開始,以step所代表的數字為步長;
例如::1~2為奇數行 2~2為偶數行
addr1,+N:從addr1開始,包括addr1所在行,並繼續向後計算N行;
例如:2,+7匹配到的行數為23456789一共八行,相當於2,2+7
addr1,~N:從addr1開始,包括addr1所在行,向後計算addr1*N行;
例如:2,~5相當於2,2*5
/pattern1/,/pattern2/:從被pattern1匹配的第一行開始計算,一直到被/pattern2/匹配到的第一行結束;
Command(處理命令):
=:顯示被模式匹配的行的行號
例如:sed -n‘/^$/=‘ /etc/grub2.cfg
a\text:在被模式匹配的行的後面追加text的內容,支持使用\n換行,從而實現多行追加;
i \text:在被模式匹配的行的前面插入text的內容,支持使用\n換行,從而實現多行插入;
c \text:將被模式匹配的行的修改為text的內容,支持使用\n換行,從而實現一行變多行;
d:在模式空間中刪除被模式匹配的行;這樣的行不能再進行標準輸出;
註意:在使用d命令的時候,不宜使用-n選項;
p:顯示模式空間中被模式匹配的行;
註意:在使用p命令的時候,通常會搭配-n選項;
w filepath:將模式空間中被模式匹配的行,另存到filepath文件中;
r filepath:將filepath文件的內容追加至模式空間中被模式匹配的行之後;
!Command:在模式空間中被模式匹配的行,不執行Command命令;相反,未被模式匹配的行,參會執行Command命令
s///:查找替換,分隔符可以任意更換,只要相同即可;
s@@@, s###, s,,,
s/pattern/text/[control]
s@/etc/fstab@/etc/mtab@
pattern:計劃查找並替換的內容
text:要替換的結果
control:如何進行替換
g:行內全部替換
p:顯示替換成功的行
w filepath:將替換成功的行另存到filepath文件中;
支持後向引用:
s/\(string\)/&/
s/\(string\)/\1/
高級編輯命令:
h: 把模式空間中的內容覆蓋至保持空間中
H:把模式空間中的內容追加至保持空間中
g: 從保持空間取出數據覆蓋至模式空間
G:從保持空間取出內容追加至模式空間
x: 把模式空間中的內容與保持空間中的內容進行互換
n: 讀取匹配到的行的下一行覆蓋至模式空間
N:追加匹配到的行的下一行至模式空間
d: 刪除模式空間中的行
D:刪除多行模式空間中的所有行
本文出自 “12657170” 博客,請務必保留此出處http://12667170.blog.51cto.com/12657170/1930754
sed命令及vim的末行命令