亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

Linux系統sed命令怎么使用

發布時間:2022-01-21 12:48:46 來源:億速云 閱讀:153 作者:iii 欄目:開發技術

這篇文章主要講解了“Linux系統sed命令怎么使用”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Linux系統sed命令怎么使用”吧!

Linux系統sed命令怎么使用

我們知道,Vim 采用的是交互式文本編輯模式,你可以用鍵盤命令來交互性地插入、刪除或替換數據中的文本。但本節要講的 sed 命令不同,它采用的是流編輯模式,最明顯的特點是,在 sed 處理數據之前,需要預先提供一組規則,sed 會按照此規則來編輯數據。

sed命令的使用規則

命令格式如下:

sed [option] 'command' input_file

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

-n 使用安靜(silent)模式,只列出經過sed特殊處理的那一行(或者動作)內容;
-e 直接在指令列模式上進行 sed 的動作編輯;
-f 直接將 sed 的動作寫在一個文件內, -f filename 則可以執行filename內的sed命令;
-r 讓sed命令支持擴展的正則表達式(默認是基礎正則表達式);
-i 直接修改讀取的文件內容,而不是由屏幕輸出;

常用的命令有以下幾種:

a \: 即append追加字符串,可將其后的字符加在所選擇內容的后面
c \: 取代/替換字符串,可將其后內容替換至所選內容
d  : 即delete刪除,該命令會將當前選中的行刪除
i \: 即insert插入字符串,可將其后內容插入至所選內容前
p  : print即打印,該命令會打印當前選擇的行到屏幕上
s  : 替換,通常s命令的用法是這樣的:1,2s/old/new/g,將old字符串替換成new字符串

命令示例

假設有一個本地文件test.txt,文件內容如下:

[root@linuxprobe ~]$ cat test.txt
this is first line
this is second line
this is third line
this is fourth line
this fifth line
happy everyday
end

本節將使用該文件詳細演示每一個命令的用法。

a命令

[root@linuxprobe ~]$ sed '1a \add one' test.txt
this is first line
add one
this is secondline
this is third line
this is fourth line
this is fifth line
happy everyday
end

本例命令部分中的1表示第一行,同樣的第二行寫成2,第一行到第三行寫成1,3,用表示最后一行,比如表示第二行到最后一行中間所有的行(包含第二行和最后一行)。
本例的作用是在第一行之后增加字符串”add one”,從輸出可以看到具體效果。

[root@linuxprobe ~]$ 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”字符串,從輸出可以看到效果。

[root@linuxprobe ~]$ sed '/first/a \add one' test.txt
this is first line
add one
this is secondline
this is third line
this is fourth line
this is fifth line
happy everyday
end

本例表示在包含”first”字符串的行的后面加上字符串”add one”,從輸出可以看到第一行包含first,所以第一行之后增加了”add one”

[root@linuxprobe ~]$ sed '/^ha.*day$/a \add one' test.txt
this is first line
this is secondline
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命令

[root@linuxprobe ~]$ sed '$c \add one' test.txt
this is first line
this is secondline
this is third line
this is fourth line
this is     fifth line
happy everyday
add one

本例表示將最后一行替換成字符串”add one”,從輸出可以看到效果。

[root@linuxprobe ~]$ sed '4,$c \add one' test.txt
this is first line
this is secondline
this is third line
add one

本例將第四行到最后一行的內容替換成字符串”add one”。

[root@linuxprobe ~]$ sed '/^ha.*day$/c \replace line' test.txt
this is first line
this is secondline
this is third line
this is fourth line
this is fifth line
replace line
end

本例將以ha開頭,以day結尾的行替換成”replace line”。

d命令

[root@linuxprobe ~]$ sed '/^ha.*day$/d' test.txt
this isfirst line
this issecond line
this isthird line
this isfourth line
this isfifth line
end

本例刪除以ha開頭,以day結尾的行。

[root@linuxprobe ~]$ sed '4,$d' test.txt
thisis first line
thisis second line
thisis third line

本例刪除第四行到最后一行中的內容。

p命令

[root@linuxprobe ~]$ sed -n '4,$p' test.txt
thisis fourth line
thisis fifth line
happy everyday
end

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

[root@linuxprobe ~]$ sed -n '/^ha.*day$/p' test.txt
happy everyday

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

s命令

實際運用中s命令式最常使用到的。

[root@linuxprobe ~]$ sed 's/line/text/g' test.txt
this isfirst text
this issecond text
this isthird text
this isfourth text
this isfifth text
happy everyday
end

本例將文件中的所有line替換成text,最后的g是global的意思,也就是全局替換,如果不加g,則只會替換本行的第一個line。

[root@linuxprobe ~]$ sed '/^ha.*day$/s/happy/very happy/g' test.txt
this isfirst line
this issecond line
this isthird line
this isfourth line
this isfifth line
very happy everyday
end

本例首先匹配以ha開始,以day結尾的行,本例中匹配到的行是”happy everyday”這樣,然后再將該行中的happy替換成very happy。

[root@linuxprobe ~]$ sed 's/\(.*\)line$/\1/g' test.txt
thisis first
thisis second
thisis third
thisis fourth
thisis fifth
happy everyday
end

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

[root@linuxprobe ~]$ 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。

感謝各位的閱讀,以上就是“Linux系統sed命令怎么使用”的內容了,經過本文的學習后,相信大家對Linux系統sed命令怎么使用這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節

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

AI

塔城市| 高邮市| 雅安市| 韶关市| 辽宁省| 新竹市| 湛江市| 富阳市| 永春县| 大丰市| 温宿县| 汉中市| 洛浦县| 延长县| 吉安县| 北辰区| 竹山县| 沙雅县| 娄烦县| 益阳市| 石门县| 西昌市| 信丰县| 霍州市| 沧州市| 微山县| 新巴尔虎左旗| 合山市| 浪卡子县| 四子王旗| 青浦区| 丰县| 碌曲县| 天全县| 辉南县| 富源县| 古田县| 沿河| 太康县| 灵武市| 宝兴县|