Sed命令解析

轉自:http://www.cnblogs.com/wangkangluo1/archive/2012/04/19/2456968.html

1.簡介
sed是非交互式的編輯器。它不會修改文件,除非使用shell重定向來保存結果。默認情況下,所有的輸出行都被打印到屏幕上。
sed編輯器逐行處理文件(或輸入),並將結果發送到屏幕。具體過程如下:首先sed把當前正在處理的行保存在一個臨時緩存區中(也稱爲模式空間),然後處理臨時緩衝區中的行,完成後把該行發送到屏幕上。sed每處理完一行就將其從臨時緩衝區刪除,然後將下一行讀入,進行處理和顯示。處理完輸入文件的最後一行後,sed便結束運行。sed把每一行都存在臨時緩衝區中,對這個副本進行編輯,所以不會修改原文件。
 
 
 
 
 
2.定址
定址用於決定對哪些行進行編輯。地址的形式可以是數字、正則表達式、或二者的結合。如果沒有指定地址,sed將處理輸入文件的所有行。
 
地址是一個數字,則表示行號;是“$"符號,則表示最後一行。例如: 
 
 

sed -'3p' datafile
只打印第三行

 

 只顯示指定行範圍的文件內容,例如:

# 只查看文件的第100行到第200行
sed -n '100,200p' mysql_slow_query.log

 

地址是逗號分隔的,那麼需要處理的地址是這兩行之間的範圍(包括這兩行在內)。範圍可以用數字、正則表達式、或二者的組合表示。例如:

sed '2,5d' datafile
#刪除第二到第五行
sed '/My/,/You/d' datafile
#刪除包含"My"行到包含"You"行之間的行
sed '/My/,10d' datafile
#刪除包含"My"行到第十行的內容

 

 

 

3.命令與選項

sed命令告訴sed如何處理由地址指定的各輸入行,如果沒有指定地址則處理所有的輸入行。

 

3.1 sed命令

 命令  功能
 a\

 在當前行後添加一行或多行。多行時除最後一行外,每行末尾需用“\”續行

 c\  用此符號後的新文本替換當前行中的文本。多行時除最後一行外,每行末尾需用"\"續行
 i\  在當前行之前插入文本。多行時除最後一行外,每行末尾需用"\"續行
 d  刪除行
 h  把模式空間裏的內容複製到暫存緩衝區
 H  把模式空間裏的內容追加到暫存緩衝區
 g  把暫存緩衝區裏的內容複製到模式空間,覆蓋原有的內容
 G  把暫存緩衝區的內容追加到模式空間裏,追加在原有內容的後面
 l  列出非打印字符
 p  打印行
 n  讀入下一輸入行,並從下一條命令而不是第一條命令開始對其的處理
 q  結束或退出sed
 r  從文件中讀取輸入行
 !  對所選行以外的所有行應用命令
 s  用一個字符串替換另一個
 g  在行內進行全局替換
   
 w  將所選的行寫入文件
 x  交換暫存緩衝區與模式空間的內容
 y  將字符替換爲另一字符(不能對正則表達式使用y命令)

 

3.2 sed選項

 選項  功能
 -e  進行多項編輯,即對輸入行應用多條sed命令時使用
 -n  取消默認的輸出
 -f  指定sed腳本的文件名
 
 
 
 
4.退出狀態
sed不向grep一樣,不管是否找到指定的模式,它的退出狀態都是0。只有當命令存在語法錯誤時,sed的退出狀態纔不是0。
 
 
 
5.正則表達式元字符
 與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的行
 
 
 
 
6.範例
 
6.1 p命令
命令p用於顯示模式空間的內容。默認情況下,sed把輸入行打印在屏幕上,選項-n用於取消默認的打印操作。當選項-n和命令p同時出現時,sed可打印選定的內容。
 

sed '/my/p' datafile
#默認情況下,sed把所有輸入行都打印在標準輸出上。如果某行匹配模式my,p命令將把該行另外打印一遍。


sed -'/my/p' datafile
#選項-n取消sed默認的打印,p命令把匹配模式my的行打印一遍。

 

6.2 d命令

命令d用於刪除輸入行。sed先將輸入行從文件複製到模式空間裏,然後對該行執行sed命令,最後將模式空間裏的內容顯示在屏幕上。如果發出的是命令d,當前模式空間裏的輸入行會被刪除,不被顯示。

sed '$d' datafile
#刪除最後一行,其餘的都被顯示

sed '/my/d' datafile
#刪除包含my的行,其餘的都被顯示

 

6.3 s命令

 

sed 's/^My/You/g' datafile
#命令末端的g表示在行內進行全局替換,也就是說如果某行出現多個My,所有的My都被替換爲You。

sed -'1,20s/My$/You/gp' datafile
#取消默認輸出,處理1到20行裏匹配以My結尾的行,把行內所有的My替換爲You,並打印到屏幕上。

  

sed 's#My#Your#g' datafile
#緊跟在s命令後的字符就是查找串和替換串之間的分隔符。分隔符默認爲正斜槓,但可以改變。無論什麼字符(換行符、反斜線除外),只要緊跟s命令,就成了新的串分隔符。

 

6.4 e選項

-e是編輯命令,用於sed執行多個編輯任務的情況下。在下一行開始編輯前,所有的編輯動作將應用到模式緩衝區中的行上。

sed -'1,10d' -'s/My/Your/g' datafile

#選項-e用於進行多重編輯。第一重編輯刪除第1-3行。第二重編輯將出現的所有My替換爲Your。因爲是逐行進行這兩項編輯(即這兩個命令都在模式空間的當前行上執行),所以編輯命令的順序會影響結果。

 

6.5 r命令

r命令是讀命令。sed使用該命令將一個文本文件中的內容加到當前文件的特定位置上。

sed '/My/r introduce.txt' datafile
#如果在文件datafile的某一行匹配到模式My,就在該行後讀入文件introduce.txt的內容。如果出現My的行不止一行,則在出現My的各行後都讀入introduce.txt文件的內容。

 
6.6 w命令

sed -'/hrwang/w me.txt' datafile

 

6.7 a\ 命令

a\ 命令是追加命令,追加將添加新文本到文件中當前行(即讀入模式緩衝區中的行)的後面。所追加的文本行位於sed命令的下方另起一行。如果要追加的內容超過一行,則每一行都必須以反斜線結束,最後一行除外。最後一行將以引號和文件名結束。

sed '/^hrwang/a\
>hrwang and mjfan are husband\
>and wife'
 datafile
#如果在datafile文件中發現匹配以hrwang開頭的行,則在該行下面追加hrwang and mjfan are husband and wife

 

6.8 i\ 命令

i\ 命令是在當前行的前面插入新的文本。

 

6.9 c\ 命令

sed使用該命令將已有文本修改成新的文本。

 

6.10 n命令

sed使用該命令獲取輸入文件的下一行,並將其讀入到模式緩衝區中,任何sed命令都將應用到匹配行緊接着的下一行上。

 

sed '/hrwang/{n;s/My/Your/;}' datafile

注:如果需要使用多條命令,或者需要在某個地址範圍內嵌套地址,就必須用花括號將命令括起來,每行只寫一條命令,或這用分號分割同一行中的多條命令。
 
6.11 y命令
該命令與UNIX/Linux中的tr命令類似,字符按照一對一的方式從左到右進行轉換。例如,y/abc/ABC/將把所有小寫的a轉換成A,小寫的b轉換成B,小寫的c轉換成C。
 

sed '1,20y/hrwang12/HRWANG^$/' datafile
#將1到20行內,所有的小寫hrwang轉換成大寫,將1轉換成^,將2轉換成$
#正則表達式元字符對y命令不起作用。與s命令的分隔符一樣,斜線可以被替換成其它的字符。

 

6.12 q命令

q命令將導致sed程序退出,不再進行其它的處理。

sed '/hrwang/{s/hrwang/HRWANG/;q;}' datafile

 

6.13 h命令和g命令

#cat datafile

My name is hrwang.

Your name is mjfan.

hrwang is mjfan's husband.

mjfan is hrwang's wife.

  

sed -'/hrwang/h' -'$G' datafile

sed -e '/hrwang/H' -e '$G' datafile

#通過上面兩條命令,你會發現h會把原來暫存緩衝區的內容清除,只保存最近一次執行h時保存進去的模式空間的內容。而H命令則把每次匹配hrwnag的行都追加保存在暫存緩衝區。

sed -e '/hrwang/H' -e '$g' datafile

sed -e '/hrwang/H' -e '$G' datafile

#通過上面兩條命令,你會發現g把暫存緩衝區中的內容替換掉了模式空間中當前行的內容,此處即替換了最後一行。而G命令則把暫存緩衝區的內容追加到了模式空間的當前行後。此處即追加到了末尾。

 

 7.範例(二)

1.sed -n '2'p filename 
打印文件的第二行。 
2.sed -n '1,3'p filename 
打印文件的1到3行 
3. sed -n '/Neave/'p filename 
打印匹配Neave的行(模糊匹配) 
4. sed -n '4,/The/'p filename 
在第4行查詢模式The 
5. sed -n '1,$'p filename 
打印整個文件,$表示最後一行。 
6. sed -n '/.*ing/'p filename 
匹配任意字母,並以ing結尾的單詞(點號不能少) 
7 sed -n / -e '/music/'= filename 
打印匹配行的行號,-e 會打印文件的內容,同時在匹配行的前面標誌行號。-n只打印出實際的行號。 
8.sed -n -e '/music/'p -e '/music/'= filename 
打印匹配的行和行號,行號在內容的下面 
9.sed '/company/' a\ "Then suddenly it happend" filename 
選擇含有company的行,將後面的內容"Then suddenly it happend"加入下一行。注意:它並不改變文件,所有操作在緩衝區,如果要保存輸出,重定向到一個文件。 
10. sed '/company/' i\ "Then suddenly it happend" filename 
同9,只是在匹配的行前插入 
11.sed '/company/' c\ "Then suddenly it happend" filename 
"Then suddenly it happend"替換匹配company的行的內容。 
12.sed '1'd ( '1,3''$''/Neave/'d) filename 
刪除第一行(1到3行,最後一行,匹配Neave的行) 
13.[ address [,address]] s/ pattern-to-find /replacement-pattern/[g p w n] 
s選項通知s e d這是一個替換操作,並查詢pattern-to-find,成功後用replacement-pattern替換它。 
替換選項如下: 
g 缺省情況下只替換第一次出現模式,使用g選項替換全局所有出現模式。 
p 缺省s e d將所有被替換行寫入標準輸出,加p選項將使- n選項無效。- n選項不打印輸出結果。 
w 文件名使用此選項將輸出定向到一個文件。(注意只將匹配替換的行寫入文件,而不是整個內容) 
14.sed s'/nurse/"hello "&/' filename 
'hello '增加到'nurse' 的前面。 
15. sed '/company/r append.txt' filename 
在匹配company的行的下一行開始加入文件append.txt的內容。 
16. sed '/company/'q filename 
首次匹配company後就退出sed程序

 

 

 

sed '1,3d' file //刪除1-3行

 

sed '/[Aa]bc/p' file //打印包含Abc或者abc的行

 

sed '/ABC/d' //刪除包含ABC的行

 

sed '/ABC/!d' //不刪除包含ABC的行

 

sed '5,$d' //從第五行到最後一行全部刪除

 

sed 1q  //顯示第一行

 

sed 's/$/.../g' //每行的最後面添加 ...

 

sed 's/d.(sk)/1&/g' //滿足d*sk的單詞,在單詞前添加sk

 

sed 's/<[^>]*>//g' //去除html標籤

 

sed '/ABC/a123' //在包含ABC的行後面添加一行數值爲123的行

 

sed '/ABC/i123' //跟a不同的是i是插入當前行的前面

 

sed '/ABC/c123' //包含ABC的行將更改爲123

 

sed '/ABC/{n;s/123/ABC/g}' //精確匹配包含ABC的下一行,將123全部替換成ABC

 

sed '/ABC/{s/A/a/}' //在包含ABC的行將A替換成a

 

sed -e '/ABC/h' -e '$g' //將包含ABC的行復制,在最後一行添加.

 

sed -e '/ABC/{h;d}' -e '/123/G' //將包含ABC的行復制並刪除,在包含123的行後添加.

 

g等於在當前行覆蓋,G是在符合條件的行後新增加一行.

 

sed 's/^/ /g' //每行前面增加一個空格

 

sed 's/.(.)$/*1/' //將倒數第二位換成*

 

sed '/ABC/!s/1/*/g' //在不包含ABC的行裏,將所有的1替換成*

 

sed 's/1|2|3/*/g' //在GNU裏將不管是1或2或者是3替換成*

 

sed -i '20,30d' filename 刪除第20-30行

 

 

 

8. sed腳本

sed腳本就是寫在文件中的一列sed命令。腳本中,要求命令的末尾不能有任何多餘的空格或文本。如果在一行中有多個命令,要用分號分隔。執行腳本時,sed先將輸入文件中第一行復制到模式緩衝區,然後對其執行腳本中所有的命令。每一行處理完畢後,sed再複製文件中下一行到模式緩衝區,對其執行腳本中所有命令。使用sed腳本時,不再用引號來確保sed命令不被shell解釋。例如sed腳本script:

#handle datafile
3i\
~~~~~~~~~~~~~~~~~~~~~
3,$s/\(hrwang\) is
 \(mjfan\)/\2 is \1/
$a\
We will love eachother forever!!
 

 

 

 

#sed -f script datafile
My name is hrwang
Your name is mjfan
~~~~~~~~~~~~~~~~~~~~~
mjfan is hrwang's husband.          #啦啦~~~
mjfan is hrwang'
s wife.
We will love eachother forever!!




轉自:http://www.cnblogs.com/ggjucheng/archive/2013/01/13/2856901.html

簡介

sed 是一種在線編輯器,它一次處理一行內容。處理時,把當前處理的行存儲在臨時緩衝區中,稱爲“模式空間”(pattern space),接着用sed命令處理緩衝區中的內容,處理完成後,把緩衝區的內容送往屏幕。接着處理下一行,這樣不斷重複,直到文件末尾。文件內容並沒有 改變,除非你使用重定向存儲輸出。Sed主要用來自動編輯一個或多個文件;簡化對文件的反覆操作;編寫轉換程序等。

 

sed使用參數

複製代碼
[root@www ~]# sed [-nefr] [動作]
選項與參數:
-n :使用安靜(silent)模式。在一般 sed 的用法中,所有來自 STDIN 的數據一般都會被列出到終端上。但如果加上 -n 參數後,則只有經過sed 特殊處理的那一行(或者動作)纔會被列出來。
-e :直接在命令列模式上進行 sed 的動作編輯;
-f :直接將 sed 的動作寫在一個文件內, -f filename 則可以運行 filename 內的 sed 動作;
-r :sed 的動作支持的是延伸型正規表示法的語法。(默認是基礎正規表示法語法)
-i :直接修改讀取的文件內容,而不是輸出到終端。

動作說明: [n1[,n2]]function
n1, n2 :不見得會存在,一般代表『選擇進行動作的行數』,舉例來說,如果我的動作是需要在 1020 行之間進行的,則『 10,20[動作行爲] 』

function:
a :新增, a 的後面可以接字串,而這些字串會在新的一行出現(目前的下一行)~
c :取代, c 的後面可以接字串,這些字串可以取代 n1,n2 之間的行!
d :刪除,因爲是刪除啊,所以 d 後面通常不接任何咚咚;
i :插入, i 的後面可以接字串,而這些字串會在新的一行出現(目前的上一行);
p :列印,亦即將某個選擇的數據印出。通常 p 會與參數 sed -n 一起運行~
s :取代,可以直接進行取代的工作哩!通常這個 s 的動作可以搭配正規表示法!例如 1,20s/old/new/g 就是啦!
複製代碼

 

以行爲單位的新增/刪除


將 /etc/passwd 的內容列出並且列印行號,同時,請將第 2~5 行刪除!

[root@www ~]# nl /etc/passwd | sed '2,5d'
1 root:x:0:0:root:/root:/bin/bash
6 sync:x:5:0:sync:/sbin:/bin/sync
7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
.....(後面省略).....


sed 的動作爲 '2,5d' ,那個 d 就是刪除!因爲 2-5 行給他刪除了,所以顯示的數據就沒有 2-5 行羅~ 另外,注意一下,原本應該是要下達 sed -e 纔對,沒有 -e 也行啦!同時也要注意的是, sed 後面接的動作,請務必以 '' 兩個單引號括住喔!

只要刪除第 2 行

nl /etc/passwd | sed '2d' 

 

要刪除第 3 到最後一行

 nl /etc/passwd | sed '3,$d' 

 

在第二行後(亦即是加在第三行)加上『drink tea?』字樣!

[root@www ~]# nl /etc/passwd | sed '2a drink tea'
1 root:x:0:0:root:/root:/bin/bash
2 bin:x:1:1:bin:/bin:/sbin/nologin
drink tea
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
.....(後面省略).....

 

那如果是要在第二行前

 nl /etc/passwd | sed '2i drink tea' 

 

如果是要增加兩行以上,在第二行後面加入兩行字,例如『Drink tea or .....』與『drink beer?』

複製代碼
[root@www ~]# nl /etc/passwd | sed '2a Drink tea or ......\
> drink beer ?'
1 root:x:0:0:root:/root:/bin/bash
2 bin:x:1:1:bin:/bin:/sbin/nologin
Drink tea or ......
drink beer ?
3 daemon:x:2:2:daemon:/sbin:/sbin/nologin
.....(後面省略).....
複製代碼

每一行之間都必須要以反斜槓『 \ 』來進行新行的添加喔!所以,上面的例子中,我們可以發現在第一行的最後面就有 \ 存在。


以行爲單位的替換與顯示


將第2-5行的內容取代成爲『No 2-5 number』呢?

[root@www ~]# nl /etc/passwd | sed '2,5c No 2-5 number'
1 root:x:0:0:root:/root:/bin/bash
No 2-5 number
6 sync:x:5:0:sync:/sbin:/bin/sync
.....(後面省略).....


透過這個方法我們就能夠將數據整行取代了!

 

僅列出 /etc/passwd 文件內的第 5-7 行

[root@www ~]# nl /etc/passwd | sed -n '5,7p'
5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
6 sync:x:5:0:sync:/sbin:/bin/sync
7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

可以透過這個 sed 的以行爲單位的顯示功能, 就能夠將某一個文件內的某些行號選擇出來顯示。

 

數據的搜尋並顯示

搜索 /etc/passwd有root關鍵字的行

複製代碼
nl /etc/passwd | sed '/root/p'
1  root:x:0:0:root:/root:/bin/bash
1  root:x:0:0:root:/root:/bin/bash
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh
3  bin:x:2:2:bin:/bin:/bin/sh
4  sys:x:3:3:sys:/dev:/bin/sh
5  sync:x:4:65534:sync:/bin:/bin/sync
....下面忽略 
複製代碼

如果root找到,除了輸出所有行,還會輸出匹配行。

 

使用-n的時候將只打印包含模板的行。

nl /etc/passwd | sed -n '/root/p'
1  root:x:0:0:root:/root:/bin/bash

 

數據的搜尋並刪除

刪除/etc/passwd所有包含root的行,其他行輸出

nl /etc/passwd | sed  '/root/d'
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh
3  bin:x:2:2:bin:/bin:/bin/sh
....下面忽略
#第一行的匹配root已經刪除了

 

 

 

數據的搜尋並執行命令

找到匹配模式eastern的行後,

搜索/etc/passwd,找到root對應的行,執行後面花括號中的一組命令,每個命令之間用分號分隔,這裏把bash替換爲blueshell,再輸出這行:

 nl /etc/passwd | sed -n '/root/{s/bash/blueshell/;p}'
 1  root:x:0:0:root:/root:/bin/blueshell

如果只替換/etc/passwd的第一個bash關鍵字爲blueshell,就退出

nl /etc/passwd | sed -n '/bash/{s/bash/blueshell/;p;q}'    
1  root:x:0:0:root:/root:/bin/blueshell

最後的q是退出。

 

數據的搜尋並替換

除了整行的處理模式之外, sed 還可以用行爲單位進行部分數據的搜尋並取代。基本上 sed 的搜尋與替代的與 vi 相當的類似!他有點像這樣:

sed 's/要被取代的字串/新的字串/g'

 

先觀察原始信息,利用 /sbin/ifconfig 查詢 IP

[root@www ~]# /sbin/ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
inet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
.....(以下省略).....


本機的ip是192.168.1.100。

 

將 IP 前面的部分予以刪除

[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g'
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0

接下來則是刪除後續的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0

將 IP 後面的部分予以刪除

[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'
192.168.1.100

 

多點編輯

一條sed命令,刪除/etc/passwd第三行到末尾的數據,並把bash替換爲blueshell

nl /etc/passwd | sed -e '3,$d' -e 's/bash/blueshell/'
1  root:x:0:0:root:/root:/bin/blueshell
2  daemon:x:1:1:daemon:/usr/sbin:/bin/sh

-e表示多點編輯,第一個編輯命令刪除/etc/passwd第三行到末尾的數據,第二條命令搜索bash替換爲blueshell。

 

 

直接修改文件內容(危險動作)


sed 可以直接修改文件的內容,不必使用管道命令或數據流重導向! 不過,由於這個動作會直接修改到原始的文件,所以請你千萬不要隨便拿系統配置來測試! 我們還是使用下載的 regular_express.txt 文件來測試看看吧!

利用 sed 將 regular_express.txt 內每一行結尾若爲 . 則換成 !

[root@www ~]# sed -i 's/\.$/\!/g' regular_express.txt

 

利用 sed 直接在 regular_express.txt 最後一行加入『# This is a test』

[root@www ~]# sed -i '$a # This is a test' regular_express.txt

由於 $ 代表的是最後一行,而 a 的動作是新增,因此該文件最後新增『# This is a test』!

sed 的『 -i 』選項可以直接修改文件內容,這功能非常有幫助!舉例來說,如果你有一個 100 萬行的文件,你要在第 100 行加某些文字,此時使用 vim 可能會瘋掉!因爲文件太大了!那怎辦?就利用 sed 啊!透過 sed 直接修改/取代的功能,你甚至不需要使用 vim 去修訂!


發佈了37 篇原創文章 · 獲贊 22 · 訪問量 32萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章