Linux中文字處理命令sed的使用示例分享
這篇文章主要介紹了Linux中文字處理命令sed的使用示例 ,sed命令的使用是Linux入門學習中的基礎知識,需要的朋友可以參考下
sed對文字的處理很強大,並且sed非常小,引數少,容易掌握,他的操作方式根awk有點像。sed按順序逐行讀取檔案。然後,它執行為該行指定的所有操作,並在完成請求的修改之後的內容顯示出來,也可以存放到檔案中。完成了一行上的所有操作之後,它讀取檔案的下一行,然後重複該過程直到它完成該檔案。在這裡要注意一點,原始檔(預設地)保持不被修改。sed 預設讀取整個檔案並對其中的每一行進行修改。說白了就是一行一行的操作。我用sed主要就是用裡面的替換功能,真的很強大。下面以例項,詳細的說一下,先從替換開始,最常用的。
引數
sed -h
-n, --quiet, --silent 取消自動列印模式空間
-e 指令碼, --expression=指令碼 新增“指令碼”到程式的執行列表
-f 指令碼檔案, --file=指令碼檔案 新增“指令碼檔案”到程式的執行列表
--follow-symlinks 直接修改檔案時跟隨軟連結
-i[副檔名], --in-place[=副檔名] 直接修改檔案(如果指定副檔名就備份檔案)
-l N, --line-length=N 指定“l”命令的換行期望長度
--posix 關閉所有 GNU 擴充套件
-r, --regexp-extended 在指令碼中使用擴充套件正規表示式
-s, --separate 將輸入檔案視為各個獨立的檔案而不是一個長的連續輸入
-u, --unbuffered 從輸入檔案讀取最少的資料,更頻繁的重新整理輸出
--help 列印幫助並退出
--version 輸出版本資訊並退出
例1
測試檔案
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
&nobody:$:99:99:nobody:/:/bin/false
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例a,這個例子,把test檔案中的root替換成tankzhang,只不過只替換一次及終止在這一行的操作,轉到下一行
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/' test |grep tank
tankzhang:x:0:0:root:/root:/bin/bash
例b,這個例子,用tankzhang把檔案test中的root全部替換掉,請注意g這個字母,global的縮寫
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/g' test |grep zhang
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
例c,加了-n p後表示只列印那些發生替換的行(部分替換),上面的例子,我並沒有加上grep
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/p' test
tankzhang:x:0:0:root:/root:/bin/bash
例d,加了-n pg後表示只列印那些發生替換的行(全部替換),上面的例子,我並沒有加上grep
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/pg' test
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
例e,在第二行,到第八行之間,替換以zhang開頭的行,用ying來替換,並顯示替換的行
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/^zhang/ying/gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
例f,當有多個命令要執行時,可以用分號來分開,並且分隔符可以自定義,預設是/。上面的例子意思是在第二行,到第八行之間,替換以zhang開頭的行,用ying來替換,在5,到10間,用goodbay來替換dbus,並顯示替換的行
[zhangy@BlackGhost mytest]# cat test | sed -n '2,8s/^zhang/ying/gp;5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例g,這個例子根上面的那個例子一樣,只不過有一點不同,那就是-e來充當了分號的作用,-e也能分割多個命令。
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/zhang/ying/gp' -ne '5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例h,正則的用法,在sed裡面用括號的話要加上\的,不然會報錯的。
[zhangy@BlackGhost mytest]# sed -ne '2,8s/^\(zhangy\)/\1ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
[root@masters ~]# sed -ne '2,8s/^\(zhangy\)/&ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
例i,&的用處是,在找到的字串後加上&後面的字串,zhang後都加上了ying
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhang/&ying/gp' test
zhangyingy:x:1000:100:,,,:/home/zhangyingy:/bin/bash
ba:x:1002:1002::/home/zhangyingy:/bin/bash
@zhangyingying:*:1004:1004::/home/test:/bin/bash
例j,這個例子是說,在以zhang開頭的行開始,到匹配Po的行結束,在他們之間進行替換
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例k,n;這裡的n是next的縮寫,找到root的行後,將其下一行的中的bin換成tank
[zhangy@BlackGhost mytest]$ sed '/root/{n;s/bin/tank/}' test
root:x:0:0:root:/root:/bin/bash
tank:x:1:1:bin:/bin:/bin/false
例m,y的作用是將匹配的字元換成大寫,不過替換字元和被替換字元長度要一樣
[zhangy@BlackGhost mytest]$ sed -e '1,2y/root/ROOT/' test
ROOT:x:0:0:ROOT:/ROOT:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
例n,h的作用是將找到的行,放到一個快取區,G的作用是將快取區中的內容放到最後一行
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '$G' test
................................
.............................
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例o,行替換,用匹配root的行,來替換匹配zhangy的行
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '/zhangy/g' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
&nobody:$:99:99:nobody:/:/bin/false
root:x:0:0:root:/root:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
root:x:0:0:root:/root:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例p,這個例子是說,在以zhang開頭的行開始,到匹配Po的行結束,在他們之間進行替換
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例q,3q的意思是到第三行的時候,退出
[zhangy@BlackGhost mytest]$ sed -e 's/bin/tank/g;3q' test
root:x:0:0:root:/root:/tank/bash
tank:x:1:1:tank:/tank:/tank/false
daemon:x:2:2:daemon:/stank:/tank/false
例r,特殊匹配
匹配數字別忘了中括號外面還有一箇中括號。
[:alnum:] 字母數字 [a-z A-Z 0-9]
[:alpha:] 字母 [a-z A-Z]
[:blank:] 空格或製表鍵
[:cntrl:] 任何控制字元
[:digit:] 數字 [0-9]
[:graph:] 任何可視字元(無空格)
[:lower:] 小寫 [a-z]
[:print:] 非控制字元
[:punct:] 標點字元
[:space:] 空格
[:upper:] 大寫 [A-Z]
[:xdigit:] 十六進位制數字 [0-9 a-f A-F]
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhangy.*[[:digit:]]/=======/gp' test
=======:,,,:/home/zhangy:/bin/bash
@=======::/home/test:/bin/bash
例2
例a,刪除1,14行
[zhangy@BlackGhost test]$ sed -e '1,14d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例b,刪除4以後的行,包括第4行,把$當成最大行數就行了。
[zhangy@BlackGhost mytest]$ sed -e '4,$d' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例c,刪除包括false的行,或者包括bash的行,別忘了加\
[zhangy@BlackGhost mytest]$ sed -e '/\(false\|bash\)$/d' test
policykit:x:102:1005:Po
例d,刪除從匹配root的行,到匹配以test開頭的行,中間的行
[zhangy@BlackGhost mytest]$ sed -e '/root/,/^test/d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例3
例a,讀取test2的內容,並將其寫入到匹配行的下面
[zhangy@BlackGhost mytest]$ sed -e '/^root/r test2' test
root:x:0:0:root:/root:/bin/bash
=============
-------------
+++++++++++++
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例b,將匹配數字的行,寫入test2中
[zhangy@BlackGhost mytest]$ sed '/[[:digit:]]/w test2' test
例c,將要插入的東西,插入匹配行的下面
[zhangy@BlackGhost mytest]$ sed '/root/a\\ ===aaaa====' test
root:x:0:0:root:/root:/bin/bash
===aaaa====
bin:x:1:1:bin:/bin:/bin/false
例d,正好根a相反,將要插入的東西,插入到匹配行的上面
[zhangy@BlackGhost mytest]$ sed '/^daemon/i\\=================' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
=================
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
例4
#取得一個檔案(或目錄)路徑的父目錄,s@@@為替換格式,\(/.*/\)是指一個"/"後面跟了任意字元又跟了一個"/",其中\(\)是用來把匹配內容作為一個整體後向引用,[^/]\{1,\}是指一個非"/"字元出現了一次,兩次,或多次;/\?是指"/"出現了0次或1次,\1是後向引用前面匹配的內容
[root@practice ~]# echo "/usr/local/bin/" |sed 's@\(/.*/\)[^/]\{1,\}/\?@\1@' /usr/local/
#使用擴充套件正規表示式後,亦可如此:
[root@practice ~]# echo "/etc/rc.d/rc.sysinit" | sed -r 's@(/.*/)[^/]+/?@\1@' /etc/rc.d/
sed對文字的處理很強大,並且sed非常小,引數少,容易掌握,他的操作方式根awk有點像。sed按順序逐行讀取檔案。然後,它執行為該行指定的所有操作,並在完成請求的修改之後的內容顯示出來,也可以存放到檔案中。完成了一行上的所有操作之後,它讀取檔案的下一行,然後重複該過程直到它完成該檔案。在這裡要注意一點,原始檔(預設地)保持不被修改。sed 預設讀取整個檔案並對其中的每一行進行修改。說白了就是一行一行的操作。我用sed主要就是用裡面的替換功能,真的很強大。下面以例項,詳細的說一下,先從替換開始,最常用的。
引數
sed -h
-n, --quiet, --silent 取消自動列印模式空間
-e 指令碼, --expression=指令碼 新增“指令碼”到程式的執行列表
-f 指令碼檔案, --file=指令碼檔案 新增“指令碼檔案”到程式的執行列表
--follow-symlinks 直接修改檔案時跟隨軟連結
-i[副檔名], --in-place[=副檔名] 直接修改檔案(如果指定副檔名就備份檔案)
-l N, --line-length=N 指定“l”命令的換行期望長度
--posix 關閉所有 GNU 擴充套件
-r, --regexp-extended 在指令碼中使用擴充套件正規表示式
-s, --separate 將輸入檔案視為各個獨立的檔案而不是一個長的連續輸入
-u, --unbuffered 從輸入檔案讀取最少的資料,更頻繁的重新整理輸出
--help 列印幫助並退出
--version 輸出版本資訊並退出
例1
測試檔案
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
&nobody:$:99:99:nobody:/:/bin/false
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例a,這個例子,把test檔案中的root替換成tankzhang,只不過只替換一次及終止在這一行的操作,轉到下一行
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/' test |grep tank
tankzhang:x:0:0:root:/root:/bin/bash
例b,這個例子,用tankzhang把檔案test中的root全部替換掉,請注意g這個字母,global的縮寫
[zhangy@BlackGhost mytest]# sed 's/root/tankzhang/g' test |grep zhang
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
zhangy:x:1000:100:,,,:/home/zhangy:/bin/bash
ba:x:1002:1002::/home/zhangy:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
例c,加了-n p後表示只列印那些發生替換的行(部分替換),上面的例子,我並沒有加上grep
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/p' test
tankzhang:x:0:0:root:/root:/bin/bash
例d,加了-n pg後表示只列印那些發生替換的行(全部替換),上面的例子,我並沒有加上grep
[zhangy@BlackGhost mytest]# sed -n 's/root/tankzhang/pg' test
tankzhang:x:0:0:tankzhang:/tankzhang:/bin/bash
例e,在第二行,到第八行之間,替換以zhang開頭的行,用ying來替換,並顯示替換的行
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/^zhang/ying/gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
例f,當有多個命令要執行時,可以用分號來分開,並且分隔符可以自定義,預設是/。上面的例子意思是在第二行,到第八行之間,替換以zhang開頭的行,用ying來替換,在5,到10間,用goodbay來替換dbus,並顯示替換的行
[zhangy@BlackGhost mytest]# cat test | sed -n '2,8s/^zhang/ying/gp;5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/zhangy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例g,這個例子根上面的那個例子一樣,只不過有一點不同,那就是-e來充當了分號的作用,-e也能分割多個命令。
[zhangy@BlackGhost mytest]# cat test | sed -ne '2,8s/zhang/ying/gp' -ne '5,10s#dbus#goodbay#gp'
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
goodbay:x:81:81:System message bus:/:/bin/false
例h,正則的用法,在sed裡面用括號的話要加上\的,不然會報錯的。
[zhangy@BlackGhost mytest]# sed -ne '2,8s/^\(zhangy\)/\1ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
[root@masters ~]# sed -ne '2,8s/^\(zhangy\)/&ing/gp' test
zhangying:x:1000:100:,,,:/home/zhangy:/bin/bash
例i,&的用處是,在找到的字串後加上&後面的字串,zhang後都加上了ying
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhang/&ying/gp' test
zhangyingy:x:1000:100:,,,:/home/zhangyingy:/bin/bash
ba:x:1002:1002::/home/zhangyingy:/bin/bash
@zhangyingying:*:1004:1004::/home/test:/bin/bash
例j,這個例子是說,在以zhang開頭的行開始,到匹配Po的行結束,在他們之間進行替換
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例k,n;這裡的n是next的縮寫,找到root的行後,將其下一行的中的bin換成tank
[zhangy@BlackGhost mytest]$ sed '/root/{n;s/bin/tank/}' test
root:x:0:0:root:/root:/bin/bash
tank:x:1:1:bin:/bin:/bin/false
例m,y的作用是將匹配的字元換成大寫,不過替換字元和被替換字元長度要一樣
[zhangy@BlackGhost mytest]$ sed -e '1,2y/root/ROOT/' test
ROOT:x:0:0:ROOT:/ROOT:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
例n,h的作用是將找到的行,放到一個快取區,G的作用是將快取區中的內容放到最後一行
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '$G' test
................................
.............................
ba:x:1002:1002::/home/zhangy:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
@zhangying:*:1004:1004::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例o,行替換,用匹配root的行,來替換匹配zhangy的行
[zhangy@BlackGhost mytest]$ sed -e '/root/h' -e '/zhangy/g' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
ftp:x:14:11:ftp:/home/ftp:/bin/false
&nobody:$:99:99:nobody:/:/bin/false
root:x:0:0:root:/root:/bin/bash
http:x:33:33::/srv/http:/bin/false
dbus:x:81:81:System message bus:/:/bin/false
hal:x:82:82:HAL daemon:/:/bin/false
mysql:x:89:89::/var/lib/mysql:/bin/false
aaa:x:1001:1001::/home/aaa:/bin/bash
root:x:0:0:root:/root:/bin/bash
test:x:1003:1003::/home/test:/bin/bash
root:x:0:0:root:/root:/bin/bash
例p,這個例子是說,在以zhang開頭的行開始,到匹配Po的行結束,在他們之間進行替換
[zhangy@BlackGhost mytest]# sed -ne '/^zhang/,/Po/s/zhang/ying/gp' test
yingy:x:1000:100:,,,:/home/yingy:/bin/bash
ba:x:1002:1002::/home/yingy:/bin/bash
@yingying:*:1004:1004::/home/test:/bin/bash
例q,3q的意思是到第三行的時候,退出
[zhangy@BlackGhost mytest]$ sed -e 's/bin/tank/g;3q' test
root:x:0:0:root:/root:/tank/bash
tank:x:1:1:tank:/tank:/tank/false
daemon:x:2:2:daemon:/stank:/tank/false
例r,特殊匹配
匹配數字別忘了中括號外面還有一箇中括號。
[:alnum:] 字母數字 [a-z A-Z 0-9]
[:alpha:] 字母 [a-z A-Z]
[:blank:] 空格或製表鍵
[:cntrl:] 任何控制字元
[:digit:] 數字 [0-9]
[:graph:] 任何可視字元(無空格)
[:lower:] 小寫 [a-z]
[:print:] 非控制字元
[:punct:] 標點字元
[:space:] 空格
[:upper:] 大寫 [A-Z]
[:xdigit:] 十六進位制數字 [0-9 a-f A-F]
[zhangy@BlackGhost mytest]# sed -ne '2,15s/zhangy.*[[:digit:]]/=======/gp' test
=======:,,,:/home/zhangy:/bin/bash
@=======::/home/test:/bin/bash
例2
例a,刪除1,14行
[zhangy@BlackGhost test]$ sed -e '1,14d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例b,刪除4以後的行,包括第4行,把$當成最大行數就行了。
[zhangy@BlackGhost mytest]$ sed -e '4,$d' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例c,刪除包括false的行,或者包括bash的行,別忘了加\
[zhangy@BlackGhost mytest]$ sed -e '/\(false\|bash\)$/d' test
policykit:x:102:1005:Po
例d,刪除從匹配root的行,到匹配以test開頭的行,中間的行
[zhangy@BlackGhost mytest]$ sed -e '/root/,/^test/d' test
@zhangying:*:1004:1004::/home/test:/bin/bash
policykit:x:102:1005:Po
例3
例a,讀取test2的內容,並將其寫入到匹配行的下面
[zhangy@BlackGhost mytest]$ sed -e '/^root/r test2' test
root:x:0:0:root:/root:/bin/bash
=============
-------------
+++++++++++++
bin:x:1:1:bin:/bin:/bin/false
daemon:x:2:2:daemon:/sbin:/bin/false
例b,將匹配數字的行,寫入test2中
[zhangy@BlackGhost mytest]$ sed '/[[:digit:]]/w test2' test
例c,將要插入的東西,插入匹配行的下面
[zhangy@BlackGhost mytest]$ sed '/root/a\\ ===aaaa====' test
root:x:0:0:root:/root:/bin/bash
===aaaa====
bin:x:1:1:bin:/bin:/bin/false
例d,正好根a相反,將要插入的東西,插入到匹配行的上面
[zhangy@BlackGhost mytest]$ sed '/^daemon/i\\=================' test
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/bin/false
=================
daemon:x:2:2:daemon:/sbin:/bin/false
mail:x:8:12:mail:/var/spool/mail:/bin/false
例4
#取得一個檔案(或目錄)路徑的父目錄,s@@@為替換格式,\(/.*/\)是指一個"/"後面跟了任意字元又跟了一個"/",其中\(\)是用來把匹配內容作為一個整體後向引用,[^/]\{1,\}是指一個非"/"字元出現了一次,兩次,或多次;/\?是指"/"出現了0次或1次,\1是後向引用前面匹配的內容
[root@practice ~]# echo "/usr/local/bin/" |sed 's@\(/.*/\)[^/]\{1,\}/\?@\1@' /usr/local/
#使用擴充套件正規表示式後,亦可如此:
[root@practice ~]# echo "/etc/rc.d/rc.sysinit" | sed -r 's@(/.*/)[^/]+/?@\1@' /etc/rc.d/
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/9034054/viewspace-2075263/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux文字處理命令sed基本使用示例Linux
- sed命令簡單使用示例分享
- linux下的文字處理命令sedLinux
- 《Linux下sed命令的使用》Linux
- 命令列與Shell -> 文字處理命令之sed命令列
- Linux中sed命令b選項遮蔽指定的處理區域Linux
- sed 命令詳解及示例
- Linux:管道命令與文字處理三劍客(grep、sed、awk)Linux
- 文字處理的金剛鑽 —— sed (GNU/sed)
- 透過6個示例帶你掌握Linux sed命令!Linux
- linux sed 命令Linux
- linux sed命令Linux
- LINUX命令-sedLinux
- linux sed []命令的作用Linux
- 在Linux中,如何使用awk和sed進行文字處理?Linux
- Linux命令篇 - sed 命令Linux
- Linux sed命令用法Linux
- linux之 sed命令Linux
- 文字處理流編輯器sed命令用法大全
- 【轉】linux中的sed命令Linux
- Linux檔案處理三劍客之sedLinux
- 【Linux學習教程】Linux中Sed命令如何使用?Linux
- 幾個常用的文字處理shell 命令:find、grep、sort、uniq、sed、awk
- 在 Linux/Unix 中文字處理方式總結Linux
- Linux sed 命令詳解Linux
- Linux命令-Sed用法教程Linux
- Linux sed命令詳解Linux
- Linux系列開坑記(三)-流處理器sedLinux
- 使用 sed 命令查詢和替換檔案中的字串的 16 個示例字串
- Linux文字處理命令Linux
- sed命令使用詳解
- sed命令和find命令的結合的使用
- sed處理變數替換變數
- Linux文字處理技巧分享Linux
- Linux學習之檔案處理命令(二)目錄處理命令 && 檔案處理命令Linux
- Linux文字處理命令(轉)Linux
- 實用處理字串的linux命令字串Linux
- Linux系統中的管道命令、grep命令、sed命令和awk命令Linux