中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

sed命令怎么在Linux中使用

發布時間:2021-03-12 16:04:59 來源:億速云 閱讀:153 作者:Leah 欄目:系統運維

sed命令怎么在Linux中使用?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

sed是stream editor的簡稱,也就是流編輯器。它一次處理一行內容,處理時,把當前處理的行存儲在臨時緩沖區中,稱為“模式空間”pattern space,接著用sed命令處理緩沖區中的內容,處理完成后,把緩沖區的內容送往屏幕。接著處理下一行,這樣不斷重復,直到文件末尾。文件內容并沒有 改變,除非你使用重定向存儲輸出。

使用語法
sed命令的使用規則是這樣的:

sed [option] 'command' input_file

其中option是可選的,常用的option有如下幾種:

-n 使用安靜silent模式(想不通為什么不是-s)。在一般sed的用法中,所有來自stdin的內容一般都會被列出到屏幕上。但如果加上-n參數后,則只有經過sed特殊處理的那一行(或者動作)才會被列出來;
-e 直接在指令列模式上進行 sed 的動作編輯;
-f 直接將 sed 的動作寫在一個文件內, -f filename 則可以執行filename內的sed命令;
-r 讓sed命令支持擴展的正則表達式(默認是基礎正則表達式);
-i 直接修改讀取的文件內容,而不是由屏幕輸出。

常用的命令有以下幾種:

a \:追加行append, a \的后面跟上字符串s(多行字符串可以用\n分隔),則會在當前選擇的行的后面都加上字符串s;

c \:取代/替換行change,c \后面跟上字符串s(多行字符串可以用\n分隔),則會將當前選中的行替換成字符串s;
i \:插入行insert,i \后面跟上字符串s(多行字符串可以用\n分隔),則會在當前選中的行的前面都插入字符串s;
d:刪除行delete,該命令會將當前選中的行刪除;
p:打印print,該命令會打印當前選擇的行到屏幕上;
s:替換字符串subs,通常s命令的用法是這樣的:1,2s/old/new/g,將old字符串替換成new字符串
命令示例
假設有一個本地文件test.txt,文件內容如下:

代碼如下:


[qifuguang@winwill~]$ cat test.tx

this is first line
this is second line
this is third line
this is fourth line
this fifth line
happy everyday
end
本節將使用該文件詳細演示每一個命令的用法。

a命令(追加行)
例一

代碼如下:


[qifuguang@winwill~]$ sed '1a \add one' test.txt


this is first line
add one
this is second line
this is third line
this is fourth line
this is fifth line
happy everyday
end
本例命令部分中的1表示第一行,同樣的第二行寫成2,第一行到第三行寫成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中間所有的行(包含第二行和最后一行)。

本例的作用是在第一行之后增加字符串”add one”,從輸出可以看到具體效果。

例二

代碼如下:


[qifuguang@winwill~]$ sed '1,$a \add one' test.txt


this is first line
add one
this is second line
add one
this is third line
add one
this is fourth line
add one
this is fifth line
add one
happy everyday
add one
end
add one
本例表示在第一行和最后一行所有的行后面都加上”add one”字符串,從輸出可以看到效果。

例三

代碼如下:


[qifuguang@winwill~]$ sed '/first/a \add one' test.txt


this is first line
add one
this is second line
this is third line
this is fourth line
this is fifth line
happy everyday
end
本例表示在包含”first”字符串的行的后面加上字符串”add one”,從輸出可以看到第一行包含first,所以第一行之后增加了”add one”

例四

代碼如下:


[qifuguang@winwill~]$ sed '/^ha.*day$/a \add one' test.txt


this is first line
this is second line
this is third line
this is fourth line
this is fifth line
happy everyday
add one
end
本例使用正則表達式匹配行,^ha.*day$表示以ha開頭,以day結尾的行,則可以匹配到文件的”happy everyday”這樣,所以在該行后面增加了”add one”字符串。

i命令(插入行)
i命令使用方法和a命令一樣的,只不過是在匹配的行的前面插入字符串,所以直接將上面a命令的示例的a替換成i即可,在此就不啰嗦了。

c命令(替換行)
例五

代碼如下:


[qifuguang@winwill~]$ sed '$c \add one' test.txt


this is first line
this is second line
this is third line
this is fourth line
this is     fifth line
happy everyday
add one
本例表示將最后一行替換成字符串”add one”,從輸出可以看到效果。

例六

代碼如下:


[qifuguang@winwill~]$ sed '4,$c \add one' test.txt


this is first line
this is second line
this is third line
add one
本例將第四行到最后一行的內容替換成字符串”add one”。

例七

代碼如下:


[qifuguang@winwill~]$ sed '/^ha.*day$/c \replace line' test.txt


this is first line
this is second line
this is third line
this is fourth line
this is fifth line
replace line
end
本例將以ha開頭,以day結尾的行替換成”replace line”。

d命令(刪除行)
例八

代碼如下:


[qifuguang@winwill~]$ sed '/^ha.*day$/d' test.txt


this is first line
this is second line
this is third line
this is fourth line
this is fifth line
end
本例刪除以ha開頭,以day結尾的行。

例九

代碼如下:


[qifuguang@winwill~]$ sed '4,$d' test.txt


this is first line
this is second line
this is third line
本例刪除第四行到最后一行中的內容。

p命令(打印行)
例十

代碼如下:


[qifuguang@winwill~]$ sed -n '4,$p' test.txt


this is fourth line
this is fifth line
happy everyday
end
本例在屏幕上打印第四行到最后一行的內容,p命令一般和-n選項一起使用。

例十一

代碼如下:


[qifuguang@winwill~]$ sed -n '/^ha.*day$/p' test.txt


happy everyday
本例打印以ha開始,以day結尾的行。

s命令(替換字符串)
實際運用中s命令式最常使用到的。

例十二

代碼如下:


[qifuguang@winwill~]$ sed 's/line/text/g' test.txt


this is first text
this is second text
this is third text
this is fourth text
this is fifth text
happy everyday
end
本例將文件中的所有line替換成text,最后的g是global的意思,也就是全局替換,如果不加g,則只會替換本行的第一個line。

例十三

代碼如下:


[qifuguang@winwill~]$ sed '/^ha.*day$/s/happy/very happy/g' test.txt


this is first line
this is second line
this is third line
this is fourth line
this is fifth line
very happy everyday
end
本例首先匹配以ha開始,以day結尾的行,本例中匹配到的行是”happy everyday”這樣,然后再將該行中的happy替換成very happy。

例十四

代碼如下:


[qifuguang@winwill~]$ sed 's/\(.*\)line$/\1/g' test.txt


this is first
this is second
this is third
this is fourth
this is fifth
happy everyday
end
這個例子有點復雜,先分解一下。首先s命令的模式是s/old/new/g這樣的,所以本例的old部分即\(.*\)line$,sed命令中使用\(\)包裹的內容表示正則表達式的第n部分,序號從1開始計算,本例中只有一個\(\)所以\(.*\)表示正則表達式的第一部分,這部分匹配任意字符串,所以\(.*\)line$匹配的就是以line結尾的任何行。然后將匹配到的行替換成正則表達式的第一部分(本例中相當于刪除line部分),使用\1表示匹配到的第一部分,同樣\2表示第二部分,\3表示第三部分,可以依次這樣引用。比如下面的例子:

代碼如下:


[qifuguang@winwill~]$ sed 's/\(.*\)is\(.*\)line/\1\2/g' test.txt


this  first
this  second
this  third
this  fourth
this  fifth
happy everyday
end
正則表達式中is兩邊的部分可以用\1和\2表示,該例子的作用其實就是刪除中間部分的is。

看完上述內容,你們掌握sed命令怎么在Linux中使用的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

噶尔县| 辽阳市| 特克斯县| 新竹市| 集贤县| 太原市| 霸州市| 罗源县| 天长市| 任丘市| 凌海市| 旬邑县| 桑植县| 花莲市| 锡林郭勒盟| 镇坪县| 于田县| 准格尔旗| 宜都市| 巫溪县| 瓮安县| 大埔区| 故城县| 望都县| 承德市| 玛曲县| 佛山市| 龙山县| 天台县| 瑞安市| 科尔| 安阳县| 梅河口市| 依安县| 湄潭县| 华容县| 深州市| 兴国县| 碌曲县| 德惠市| 治县。|