想掌握強大的sed工具?收藏本文就夠了!

1. 如果要將sed編輯的結果寫入文件,需要-i參數,如果存在多個編輯指令,需要在前面添加-e參數

sed -i -e 's/hhhhh/hello/g' -i -e 's/ha/ho/g' test ,不能寫成-ie (注意:i 必須在e之前,否則會報錯)

2. ?刪除最后一行 sed '$d' file(注意這里的$和vi編輯命令中使用字符串替換命令時的$意思類似,表示文件的最后一行,不是代表單純輸入$時表示跳到一行的末尾)

3. ?刪除所有行的命令sed ?'1,$d' file,如果配合-i則相當于是清空文件(和vi編輯中?:1,$s/word1/word2/g類似,但后者需要文檔中都是同樣的單詞)

4. ?sed中刪除第n行是sed 'nd' file(類似vi編輯命令中刪除一行是使用dd),反之需要僅僅保留某行時,輸入sed 'n!d' file

這里的感嘆號的使用也可以擴展,需要活學活用,比如使用在sed -n 'n!p'即表是將除了第N行之外的所有行打印出來。

另舉例如下:某文件夾下包含了如下的文件,中間的省略號表示包含2015時間的文件有很多

-rw-------. 1 billcs billcs??? 438512 10月 27 17:50 ABM_CMdbInUser.mdb.0058.20150926

-rw-------. 1 billcs billcs??? 438512 10月 27 17:40 ABM_CMdbInUser.mdb.0072.20151010

-rw-------. 1 billcs billcs??? 438512 10月 27 17:50 ABM_CMdbInUser.mdb.0080.20151018

-rw-------. 1 billcs billcs???? 29696 10月 27 17:53 ABM_CMdbInTidB.mdb

為了將所有不包含2015時間的文件顯示出來,可以使用如下的命令:

ls -l | sed -n '/2015/!p'

5. ?sed 's/linux/bowen/2' file ?表示對每一行第二個linux字符串進行替換,不滿足條件即使處在整行第二的位置也不替換

注意:s/linux/bowen/的寫法其實默認是省略了1,即和s/linux/bowen/1的含義是一致的,只將每一行的第一個linux進行替換,如果寫成2的話則就是上面的意思了。

6. ?刪除包含某字符串的行sed '/str1/d' file(這也和vi編輯中s/str1/str2/g類似,前面的s和后面的g都是替換字符串需要的,而這里是/d,且/str1就是要將str1找出來并換成str2,而sed中執行刪除時不是替換,僅需要找出str1出來而已)

被替換的str1不需要是完整顯示且前后都是空白的字符串,可以只是完整字符串其中的一部分,例如:

file內容為

line1?? 1?????? 2?????? 3?????? 4

line2?? hello?? nihao?? haha??? bye

line3 ? xilineha ? linux?? bowen??? xixi

line4?? bowen?? unix??? linux?? haha

執行sed 's/line/hoho/2' file,結果為:

line1?? 1?????? 2?????? 3?????? 4

line2?? hello?? nihao?? haha??? bye

line3 ? xihohoha ? linux?? bowen??? xixi

line4?? bowen?? unix??? linux?? haha

即只將第三行第二個字符串中的一部分line替換成了hoho

7. ?刪除空行 sed '/^$/d' file(不包括空格,TAB和控制字符行

8. ?sed字符轉換的用法 ?sed 'y/1234/ABCD/' file

1)可以這么記憶y,相當于是每替換一個字母時都需要詢問確認一下 y or n?(切記是將全文每個對應的字符都替換,而不是只替換1234字符串

2)和tr相比較,本命令的缺點就是轉換字符和被轉換字符長度一定要相等

9. ?sed '/linux/a gbh' file和sed '/linux/a\gbh' file效果一樣(a表示在匹配行的下一行添加內容,i表示在上一行添加內容)

10. ?讀取外部文件test時,如果test和file在同一個路徑下,可以直接添加單引號,不需要輸入./test,如下:

sed '/line1/r 'test'' file

建議直接使用絕對路徑而不添加單引號

11. 使用p打印命令時需要添加-n參數,否則因為sed本身會默認將所有的行都打印出來,又由于添加了p命令,所以會使得結果中出現重復的行。

例如:輸入?sed '1p' file,由于未帶-n,第一行出現了重復

line1?? 1?????? 2?????? 3?????? 4

line1?? 1?????? 2?????? 3?????? 4

line2?? hello?? nihao?? haha??? bye

line3?? hellod? linux?? linux??? xixi

line4?? line5?? unix??? linux?? haha

12. ?sed -f sedrule file 將常用的指令寫入sedrule文件中,通過-f參數就可以進行調用,這實際上是將使用sed時單引號中的指令集中放到文件中,便于使用,所以文件中的指令不需要再加單引號。例如:cat sedrule后顯示:

/^$/d

s/linux/bowen/g

13. ?替換匹配行的下一行 ?sed '/line2/{n;s/hello/bowen/}' file (n可以理解為next的意思

如果不添加n,直接是sed '/line2/{s/hello/bowen/}' file,該命令的含義就是先定位到某一行,然后對本行進行替換操作

14. l(L的小寫)表示列出非打印字符,如常用的查看文件中TAB的命令 sed -n l file

15.?sed -n '$=' test.sh 獲取文件的總行數,和awk 'END{print NR}' test.sh效果一樣

(這和ll | wc -l獲取的結果是有差異的,wc會比前兩者少1,因為wc是計算當前文件夾下的文件數再加上文件夾本身。前面兩個是獲取直觀的文件數和隱藏的.和..的總和)

16,動態獲取文件的每一行的內容?sed -n "${n}p" test.sh ,其中n是變量,所以必須使用雙引號

注意這里必須使用雙引號,如果n為1,在使用sh -x調試時可以發現會打印成sed -n '1p' test.sh,即雙引號此時解釋成了單引號

--END--

鑒于數據分析能力越來越成為每個職場人的必備技能,所以我最近新打造了本垂直公號,這里聚焦分享數據分析和腳本編程的干貨,歡迎大家都轉起來,讓更多的人來一起碰撞,交流,提升!

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 基礎命令 主要的命令和快捷鍵 Linux系統命令由三部分組成:cmd + [options]+[operation...
    485b1aca799e閱讀 1,119評論 0 0
  • linux資料總章2.1 1.0寫的不好抱歉 但是2.0已經改了很多 但是錯誤還是無法避免 以后資料會慢慢更新 大...
    數據革命閱讀 12,218評論 2 33
  • Sed工具工作原理及特性 1. sed是流編輯器,每一次讀取一行到內存中,即稱之為模式空間(pattern spa...
    魏鎮坪閱讀 11,028評論 0 12
  • 本文承接之前寫的三十分鐘學會AWK一文,在學習完AWK之后,趁熱打鐵又學習了一下SED,不得不說這兩個工具真的堪稱...
    mylxsw閱讀 4,417評論 3 74
  • 自從十四歲遇到你 再也沒有孤獨過
    巴迪和布瑞恩閱讀 420評論 1 0