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