1. 程式人生 > >sed

sed

編輯器 command stream

sed命令:

流編輯器,按照行為單位對一個或多個文件進行編輯處理;每一次sed都會處理給定文件中的一行內容。

在sed處理文本時,將正在處理的當前行存儲到臨時緩沖區中,稱為”模式空間“;用當前行去匹配給定的pattern,如果能匹配,則使用command編輯處理,如果不匹配,則默認輸出值標準輸出,然後繼續處理下一行;直到這個文件的末尾。

默認情況下,sed的所有處理行為不會影響原文件的內容;

我們一般會使用sed命令來自動編輯一個或多個文件,然後簡化對於文件的循環操作,

sed - stream editor for filtering and transforming text

sed [OPTION]... ‘script‘ [input-file]...

選項

-n:對於不能匹配模式的行,默認不輸出到屏幕

-e script:多條件編輯

-f script-file:從指定的script-file中讀取腳本

註意:script-file為一個能夠定位到腳本文件的路徑最好為絕對路徑

-i:原文件直接編輯操作

-r:使sed支持擴展正則表達式;

script:

‘AddressesCommand‘:地址與命令之間沒有空格,必須單引號引用

Addresses(地址定界):

1.空地址:對所有文件的所有行進行處理;

2.單地址:sed對於能夠匹配該地址的那唯一一行進行處理;

num:表示行號

/pattern/: 能夠匹配該模式的所有行

$: 最後一行

3.地址範圍:

addr1,addr2:從addr1開始到addr2結束的中間所有行;包括addr1和addr2

例如:2,8,從第2行到第8行

first~step:從first標記的行號開始,以step所代表的數字為步長來計算;

例如:1~2,第1行 第3行,第5行

addr1,+N:從addr1開始,包括addr1所在行並繼續向後計算N行;

例如:2,+7 第2行開始,在數7行,總共8行,相當於2,2+7

addr1,~N:從addr1開始包括addr1所在行,向後計算addr1*N行

例如:2,~5相當於 2,2*5

/pattern1/,/pattern2/: 從被pattern1匹配的第一行開始計算,一直到被pattern2匹配到的第一行結束;

Command

=:顯示被模式匹配的行的行號

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/pattern/text/[control]

pattern:計劃查找替換的內容

text:要替換的結果

control:如何進行替換

g: 行內全部替換

p: 顯示替換成功的行

w filepath:將替換成功的行另存到filepath中;

支持後向引用:

s/\(string\)/&/

s/\(string\)/\1/

高級編輯命令:

h: 把模式空間中的內容覆蓋至保持空間中

H:把模式空間中的內容追加至保持空間中

g: 從保持空間取出數據覆蓋至模式空間

G:從保持空間取出內容追加至模式空間

x: 把模式空間中的內容與保持空間中的內容進行互換

n: 讀取匹配到的行的下一行覆蓋至模式空間

N:追加匹配到的行的下一行至模式空間

d: 刪除模式空間中的行

D:刪除多行模式空間中的所有行


示例:

sed -n ‘n;p‘ FILE

sed ‘1!G;h;$!d‘ FILE

sed ‘$!N;$!D‘ FILE

sed ‘$!d‘ FILE

sed ‘G’ FILE

sed ‘g’ FILE

sed ‘/^$/d;G’ FILE

sed ‘n;d‘ FILE

sed -n ‘1!G;h;$p‘ FILE


sed