awk和sed命令


awk
awk是一個強大的編輯工具,可以在無交互的情況下實現相當復雜的文本操作
awk是行處理器: 相比較屏幕處理的優點,在處理龐大文件時不會出現內存溢出或是處理緩慢的問題,通常用來格式化文本信息
awk處理過程: 依次對每一行進行處理,然后輸出
awk命令形式:
awk [-F|-f|-v] ‘BEGIN{} //{command1; command2} END{}’ file
 [-F|-f|-v]   大參數,-F指定分隔符,-f調用腳本,-v定義變量 var=value
'  '          引用代碼塊
BEGIN   初始化代碼塊,在對每一行進行處理之前,初始化代碼,主要是引用全局變量,設置FS分隔符
//           匹配代碼塊,可以是字符串或正則表達式
{}           命令代碼塊,包含一條或多條命令
;          多條命令使用分號分隔
END      結尾代碼塊,在對每一行進行處理之后再執行的代碼塊,主要是進行最終計算或輸出結尾摘要信息
 
特殊要點:
$0           表示整個當前行
$1           每行第一個字段
NF          字段數量變量
NR          每行的記錄號,多文件記錄遞增
FNR        與NR類似,不過多文件記錄不遞增,每個文件都從1開始
\t            制表符
\n           換行符
FS          BEGIN時定義分隔符
RS       輸入的記錄分隔符, 默認為換行符(即文本是按一行一行輸入)
~            匹配,與==相比不是精確比較
!~           不匹配,不精確比較
==         等於,必須全部相等,精確比較
!=           不等於,精確比較
&&      邏輯與
||             邏輯或
+            匹配時表示1個或1個以上
/[0-9][0-9]+/   兩個或兩個以上數字
/[0-9][0-9]*/    一個或一個以上數字
FILENAME 文件名
OFS      輸出字段分隔符, 默認也是空格,可以改為制表符等
ORS        輸出的記錄分隔符,默認為換行符,即處理結果也是一行一行輸出到屏幕
-F'[:#/]'   定義三個分隔符
 
print & $0
print 是awk打印指定內容的主要命令
awk '{print}'  /etc/passwd   ==   awk '{print $0}'  /etc/passwd  
awk '{print " "}' /etc/passwd                                           //不輸出passwd的內容,而是輸出相同個數的空行,進一步解釋了awk是一行一行處理文本
awk '{print "a"}'   /etc/passwd                                        //輸出相同個數的a行,一行只有一個a字母
awk -F":" '{print $1}'  /etc/passwd 
awk -F: '{print $1; print $2}'   /etc/passwd                   //將每一行的前二個字段,分行輸出,進一步理解一行一行處理文本
awk  -F: '{print $1,$3,$6}' OFS="\t" /etc/passwd        //輸出字段1,3,6,以制表符作為分隔符
 
-f指定腳本文件
awk -f script.awk  file
BEGIN{
FS=":"
}
{print $1}               //效果與awk -F":" '{print $1}'相同,只是分隔符使用FS在代碼自身中指定
 
awk 'BEGIN{X=0} /^$/{ X+=1 } END{print "I find",X,"blank lines."}' test 
I find 4 blank lines.
 ls -l|awk 'BEGIN{sum=0} !/^d/{sum+=$5} END{print "total size is",sum}'                    //計算文件大小
total size is 17487
 
-F指定分隔符
$1 指指定分隔符后,第一個字段,$3第三個字段, \t是制表符
一個或多個連續的空格或制表符看做一個定界符,即多個空格看做一個空格
awk -F":" '{print $1}'  /etc/passwd
awk -F":" '{print $1 $3}'  /etc/passwd                       //$1與$3相連輸出,不分隔
awk -F":" '{print $1,$3}'  /etc/passwd                       //多了一個逗號,$1與$3使用空格分隔
awk -F":" '{print $1 " " $3}'  /etc/passwd                  //$1與$3之間手動添加空格分隔
awk -F":" '{print "Username:" $1 "\t\t Uid:" $3 }' /etc/passwd       //自定義輸出  
awk -F: '{print NF}' /etc/passwd                                //顯示每行有多少字段
awk -F: '{print $NF}' /etc/passwd                              //將每行第NF個字段的值打印出來
 awk -F: 'NF==4 {print }' /etc/passwd                       //顯示只有4個字段的行
awk -F: 'NF>2{print $0}' /etc/passwd                       //顯示每行字段數量大於2的行
awk '{print NR,$0}' /etc/passwd                                 //輸出每行的行號
awk -F: '{print NR,NF,$NF,"\t",$0}' /etc/passwd      //依次打印行號,字段數,最后字段值,制表符,每行內容
awk -F: 'NR==5{print}'  /etc/passwd                         //顯示第5行
awk -F: 'NR==5 || NR==6{print}'  /etc/passwd       //顯示第5行和第6行
route -n|awk 'NR!=1{print}'                                       //不顯示第一行
 
//匹配代碼塊
//純字符匹配   !//純字符不匹配   ~//字段值匹配    !~//字段值不匹配   ~/a1|a2/字段值匹配a1或a2   
awk '/mysql/' /etc/passwd
awk '/mysql/{print }' /etc/passwd
awk '/mysql/{print $0}' /etc/passwd                   //三條指令結果一樣
awk '!/mysql/{print $0}' /etc/passwd                  //輸出不匹配mysql的行
awk '/mysql|mail/{print}' /etc/passwd
awk '!/mysql|mail/{print}' /etc/passwd
awk -F: '/mail/,/mysql/{print}' /etc/passwd         //區間匹配
awk '/[2][7][7]*/{print $0}' /etc/passwd               //匹配包含27為數字開頭的行,如27,277,2777...
awk -F: '$1~/mail/{print $1}' /etc/passwd           //$1匹配指定內容才顯示
awk -F: '{if($1~/mail/) print $1}' /etc/passwd     //與上面相同
awk -F: '$1!~/mail/{print $1}' /etc/passwd          //不匹配
awk -F: '$1!~/mail|mysql/{print $1}' /etc/passwd        
 
IF語句
必須用在{}中,且比較內容用()擴起來
awk -F: '{if($1~/mail/) print $1}' /etc/passwd                                       //簡寫
awk -F: '{if($1~/mail/) {print $1}}'  /etc/passwd                                   //全寫
awk -F: '{if($1~/mail/) {print $1} else {print $2}}' /etc/passwd            //if...else...
 
 
條件表達式
==   !=   >   >=  
awk -F":" '$1=="mysql"{print $3}' /etc/passwd  
awk -F":" '{if($1=="mysql") print $3}' /etc/passwd          //與上面相同 
awk -F":" '$1!="mysql"{print $3}' /etc/passwd                 //不等於
awk -F":" '$3>1000{print $3}' /etc/passwd                      //大於
awk -F":" '$3>=100{print $3}' /etc/passwd                     //大於等於
awk -F":" '$3<1{print $3}' /etc/passwd                            //小於
awk -F":" '$3<=1{print $3}' /etc/passwd                         //小於等於
 
邏輯運算符
&& || 
awk -F: '$1~/mail/ && $3>8 {print }' /etc/passwd         //邏輯與,$1匹配mail,並且$3>8
awk -F: '{if($1~/mail/ && $3>8) print }' /etc/passwd
awk -F: '$1~/mail/ || $3>1000 {print }' /etc/passwd       //邏輯或
awk -F: '{if($1~/mail/ || $3>1000) print }' /etc/passwd 
 
數值運算
awk -F: '$3 > 100' /etc/passwd    
awk -F: '$3 > 100 || $3 < 5' /etc/passwd  
awk -F: '$3+$4 > 200' /etc/passwd
awk -F: '/mysql|mail/{print $3+10}' /etc/passwd                    //第三個字段加10打印 
awk -F: '/mysql/{print $3-$4}' /etc/passwd                             //減法
awk -F: '/mysql/{print $3*$4}' /etc/passwd                             //求乘積
awk '/MemFree/{print $2/1024}' /proc/meminfo                  //除法
awk '/MemFree/{print int($2/1024)}' /proc/meminfo           //取整
 
輸出分隔符OFS
awk '$6 ~ /FIN/ || NR==1 {print NR,$4,$5,$6}' OFS="\t" netstat.txt
awk '$6 ~ /WAIT/ || NR==1 {print NR,$4,$5,$6}' OFS="\t" netstat.txt        
//輸出字段6匹配WAIT的行,其中輸出每行行號,字段4,5,6,並使用制表符分割字段
 
輸出處理結果到文件
①在命令代碼塊中直接輸出    route -n|awk 'NR!=1{print > "./fs"}'   
②使用重定向進行輸出           route -n|awk 'NR!=1{print}'  > ./fs
 
格式化輸出
netstat -anp|awk '{printf "%-8s %-8s %-10s\n",$1,$2,$3}' 
printf表示格式輸出
%格式化輸出分隔符
-8長度為8個字符
s表示字符串類型
打印每行前三個字段,指定第一個字段輸出字符串類型(長度為8),第二個字段輸出字符串類型(長度為8),
第三個字段輸出字符串類型(長度為10)
netstat -anp|awk '$6=="LISTEN" || NR==1 {printf "%-10s %-10s %-10s \n",$1,$2,$3}'
netstat -anp|awk '$6=="LISTEN" || NR==1 {printf "%-3s %-10s %-10s %-10s \n",NR,$1,$2,$3}'
 
IF語句
awk -F: '{if($3>100) print "large"; else print "small"}' /etc/passwd
small
small
small
large
small
small
awk -F: 'BEGIN{A=0;B=0} {if($3>100) {A++; print "large"} else {B++; print "small"}} END{print A,"\t",B}' /etc/passwd 
                                                                                                                  //ID大於100,A加1,否則B加1
awk -F: '{if($3<100) next; else print}' /etc/passwd                         //小於100跳過,否則顯示
awk -F: 'BEGIN{i=1} {if(i<NF) print NR,NF,i++ }' /etc/passwd   
awk -F: 'BEGIN{i=1} {if(i<NF) {print NR,NF} i++ }' /etc/passwd
另一種形式
awk -F: '{print ($3>100 ? "yes":"no")}'  /etc/passwd 
awk -F: '{print ($3>100 ? $3":\tyes":$3":\tno")}'  /etc/passwd
 
while語句
awk -F: 'BEGIN{i=1} {while(i<NF) print NF,$i,i++}' /etc/passwd 
7 root 1
7 x 2
7 0 3
7 0 4
7 root 5
7 /root 6
 
數組
netstat -anp|awk 'NR!=1{a[$6]++} END{for (i in a) print i,"\t",a[i]}'
netstat -anp|awk 'NR!=1{a[$6]++} END{for (i in a) printf "%-20s %-10s %-5s \n", i,"\t",a[i]}'
9523                               1     
9929                               1     
LISTEN                            6     
7903                               1     
3038/cupsd                   1     
7913                               1     
10837                             1     
9833                               1     
 
應用1
awk -F: '{print NF}' helloworld.sh                                                       //輸出文件每行有多少字段
awk -F: '{print $1,$2,$3,$4,$5}' helloworld.sh                                 //輸出前5個字段
awk -F: '{print $1,$2,$3,$4,$5}' OFS='\t' helloworld.sh                 //輸出前5個字段並使用制表符分隔輸出
awk -F: '{print NR,$1,$2,$3,$4,$5}' OFS='\t' helloworld.sh           //制表符分隔輸出前5個字段,並打印行號
 
應用2
awk -F'[:#]' '{print NF}'  helloworld.sh                                                  //指定多個分隔符: #,輸出每行多少字段
awk -F'[:#]' '{print $1,$2,$3,$4,$5,$6,$7}' OFS='\t' helloworld.sh   //制表符分隔輸出多字段
 
應用3
awk -F'[:#/]' '{print NF}' helloworld.sh                                               //指定三個分隔符,並輸出每行字段數
awk -F'[:#/]' '{print $1,$2,$3,$4,$5,$6,$7,$8,$9,$10,$11,$12}' helloworld.sh     //制表符分隔輸出多字段
 
應用4
計算/home目錄下,普通文件的大小,使用KB作為單位
ls -l|awk 'BEGIN{sum=0} !/^d/{sum+=$5} END{print "total size is:",sum/1024,"KB"}'
ls -l|awk 'BEGIN{sum=0} !/^d/{sum+=$5} END{print "total size is:",int(sum/1024),"KB"}'         //int是取整的意思
 
應用5
統計netstat -anp 狀態為LISTEN和CONNECT的連接數量分別是多少
netstat -anp|awk '$6~/LISTEN|CONNECTED/{sum[$6]++} END{for (i in sum) printf "%-10s %-6s %-3s \n", i," ",sum[i]}'
 
應用6
統計/home目錄下不同用戶的普通文件的總數是多少?
ls -l|awk 'NR!=1 && !/^d/{sum[$3]++} END{for (i in sum) printf "%-6s %-5s %-3s \n",i," ",sum[i]}'   
mysql        199 
root           374 
統計/home目錄下不同用戶的普通文件的大小總size是多少?
ls -l|awk 'NR!=1 && !/^d/{sum[$3]+=$5} END{for (i in sum) printf "%-6s %-5s %-3s %-2s \n",i," ",sum[i]/1024/1024,"MB"}'
 
應用7
輸出成績表
awk 'BEGIN{math=0;eng=0;com=0;printf "Lineno.   Name    No.    Math   English   Computer    Total\n";printf "------------------------------------------------------------\n"}{math+=$3; eng+=$4; com+=$5;printf "%-8s %-7s %-7s %-7s %-9s %-10s %-7s \n",NR,$1,$2,$3,$4,$5,$3+$4+$5} END{printf "------------------------------------------------------------\n";printf "%-24s %-7s %-9s %-20s \n","Total:",math,eng,com;printf "%-24s %-7s %-9s %-20s \n","Avg:",math/NR,eng/NR,co
 
=============================================================================================================================================================
 
sed 

sed:Stream Editor文本流編輯,sed是一個“非交互式的”面向字符流的編輯器。能同時處理多個文件多行的內容,可以不對原文件改動,把整個文件輸入到屏幕,可以把只匹配到模式的內容輸入到屏幕上。還可以對原文件改動,但是不會再屏幕上返回結果。

sed命令的語法格式:

sed的命令格式: sed [option] 'sed command'filename

sed的腳本格式:sed [option] -f 'sed script'filename

sed命令的選項(option):

-n :只打印模式匹配的行

-e :直接在命令行模式上進行sed動作編輯,此為默認選項

-f :將sed的動作寫在一個文件內,用–f filename 執行filename內的sed動作

-r :支持擴展表達式

-i :直接修改文件內容

sed在文件中查詢文本的方式:

1)使用行號,可以是一個簡單數字,或是一個行號范圍

x

x為行號

x,y

表示行號從x到y

/pattern

查詢包含模式的行

/pattern /pattern

查詢包含兩個模式的行

pattern/,x

在給定行號上查詢包含模式的行

x,/pattern/

通過行號和模式查詢匹配的行

x,y!

查詢不包含指定行號x和y的行

\

\

\

2)使用正則表達式、擴展正則表達式(必須結合-r選項)

^

錨點行首的符合條件的內容,用法格式"^pattern"

$

錨點行首的符合條件的內容,用法格式"pattern$"

^$

空白行

.

匹配任意單個字符

*

匹配緊挨在前面的字符任意次(0,1,多次)

.*

匹配任意長度的任意字符

\?

匹配緊挨在前面的字符0次或1次

\{m,n\}

匹配其前面的字符至少m次,至多n次

\{m,\}

匹配其前面的字符至少m次

\{m\}

精確匹配前面的m次\{0,n\}:0到n次

\<

錨點詞首----相當於 \b,用法格式:\<pattern

\>

錨點詞尾,用法格式:\>pattern

\<pattern\>

單詞錨點

 

分組,用法格式:pattern,引用\1,\2

[]

匹配指定范圍內的任意單個字符

[^]

匹配指定范圍外的任意單個字符

[:digit:]

所有數字, 相當於0-9, [0-9]---> [[:digit:]]

[:lower:]

所有的小寫字母

[:upper:]

所有的大寫字母

[:alpha:]

所有的字母

[:alnum:]

相當於0-9a-zA-Z

[:space:]

空白字符

[:punct:]

所有標點符號

[java] view plain copy
 
  1. #######sed的匹配模式支持正則表達式#####################  
  2. sed'5 q'/etc/passwd#打印前5行  
  3. sed-n '/r*t/p'/etc/passwd#打印匹配r有0個或者多個,后接一個t字符的行  
  4. sed-n '/.r.*/p'/etc/passwd#打印匹配有r的行並且r后面跟任意字符  
  5. sed-n '/o*/p'/etc/passwd#打印o字符重復任意次  
  6. sed-n '/o\{1,\}/p'/etc/passwd#打印o字重復出現一次以上  
  7. sed-n '/o\{1,3\}/p'/etc/passwd#打印o字重復出現一次到三次之間以上  

sed的編輯命令(sed command):

p

打印匹配行(和-n選項一起合用)

=

顯示文件行號

a\

在定位行號后附加新文本信息

i\

在定位行號后插入新文本信息

d

刪除定位行

c\

用新文本替換定位文本

w filename

寫文本到一個文件,類似輸出重定向 >

r filename

從另一個文件中讀文本,類似輸入重定向 <

s

使用替換模式替換相應模式

q

第一個模式匹配完成后退出或立即退出

l

顯示與八進制ACSII代碼等價的控制符

{}

在定位行執行的命令組,用分號隔開

n

從另一個文件中讀文本下一行,並從下一條命令而不是第一條命令開始對其的處理

N

在數據流中添加下一行以創建用於處理的多行組

g

將模式2粘貼到/pattern n/

y

傳送字符,替換單個字符

對文件的操作無非就是”增刪改查“,怎樣用sed命令實現對文件的”增刪改查“,玩轉sed是寫自動化腳本必須的基礎之一。

sed命令打印文件信息(查詢):

[java] view plain copy
 
  1. ####用sed打印文件的信息的例子的命令######  
  2. sed -n '/^#/!p'  /etc/vsftpd/vsftpd.conf         
  3. sed -n '/^#/!{/^$/!p}'  /etc/vsftpd/vsftpd.conf  
  4. sed -e '/^#/d' -e '/^$/d'  /etc/vsftpd/vsftpd.conf  
  5. sed -n '1,/adm/p' /etc/passwd  
  6. sed -n '/adm/,6p' /etc/passwd  
  7. sed -n '/adm/,4p' /etc/passwd  
  8. sed -n '/adm/,2p' /etc/passwd  
  9. ###以下圖片是對這些sed命令例子的解釋和顯示結果  

\

\

\

\

sed命令實現對文件內容的添加:(對源文件添加的話就用-i參數):

[java] view plain copy
 
  1. ####sed命令可以實現的添加######  
  2. #1)匹配行的行首添加,添加在同行  
  3. #2)匹配行的行中的某個字符后添加  
  4. #3)匹配行的行尾添加字符  
  5. #4)匹配行的行前面行添加  
  6. #5)匹配行的行后面行添加  
  7. #6)文件的行首添加一行  
  8.   [root@jie1 ~]# sed -i '1 i\sed command start' myfile  
  9. #7)文件的行尾追加一行  
  10.   [root@jie1 ~]# sed -i '$a \sed command end' myfile  

\

 

\

 

\

\

\

\

\

\

\

sed命令實現對文件內容的刪除:(對源文件直接刪除用-i參數):

sed的刪除操作是針對文件的行,如果想刪除行中的某個字符,那就用替換(別急,替換稍后就講,而且替換是sed最常用的)

\

\

\

\

 重點:sed命令實現對文件內容的替換(替換是在shell自動化腳本中用到最多的操作)

[java] view plain copy
 
  1. #================源文件里面的內容===============================  
  2. [root@jie1 ~]# cat test  
  3. anonymous_enable=YES  
  4. write_enable=YES  
  5. local_umask=022  
  6. xferlog_enable=YES  
  7. connect_from_port_20=YES  
  8. root:x:0:0:root:/root:/bin/bash  
  9. bin:x:1:1:bin:/bin:/sbin/nologin  
  10. daemon:x:2:2:daemon:/sbin:/sbin/nologin  
  11. adm:x:3:4:adm:/var/adm:/sbin/nologin  
  12. lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin  
  13. DEVICE="eth0"  
  14. BOOTPROTO="static"  
  15. HWADDR="00:0C:29:90:79:78"  
  16. ONBOOT="yes"  
  17. IPADDR=172.16.22.1  
  18. NETMASK=255.255.0.0  
  19. #======================================================================  
  20. [root@jie1 ~]# sed -i '/DEVICE/c\Ethernet' test   
  21.         #匹配DEVICE的行,替換成Ethernet這行  
  22. [root@jie1 ~]# sed -i 's/static/dhcp/' test       
  23.         #把static替換成dhcp(/,@,#都是前面所說的地址定界符)  
  24. [root@jie1 ~]# sed -i '/IPADDR/s@22\.1@10.12@' test  
  25.         #匹配IPADDR的行,把22.1替換成10.12由於.號有特殊意義所有需要轉義  
  26. [root@jie1 ~]# sed -i '/connect/s#YES#NO#' test   
  27.         #匹配connect的行,把YES替換成NO  
  28. [root@jie1 ~]# sed -i 's/bin/tom/2g' test         
  29.         #把所有匹配到bin的行中第二次及第二次之后出現bin替換成tom  
  30. [root@jie1 ~]# sed -i 's/daemon/jerry/2p' test    
  31.         #把所有匹配到bin的行中第二次出現的daemon替換成jerry,並在生產與匹配行同樣的行  
  32. [root@jie1 ~]# sed -i 's/adm/boss/2' test         
  33.         #把所有匹配到adm的行中僅僅只是第二次出現的adm替換成boss  
  34. [root@jie1 ~]# sed -i '/root/{s/bash/nologin/;s/0/1/g}' test  
  35.         #匹配root的行,把bash替換成nologin,且把0替換成1  
  36. [root@jie1 ~]# sed -i 's/root/(&)/g' test                   
  37.         #把root用括號括起來,&表示引用前面匹配的字符  
  38. [root@jie1 ~]# sed -i 's/BOOTPROTO/#BOOTPROTO/' test        
  39.         #匹配BOOTPROTO替換成#BOOTPROTO,在配置文件中一般用於注釋某行  
  40. [root@jie1 ~]# sed -i 's/ONBOOT/#&/' test                   
  41.         #匹配ONBOOT的行的前面添加#號,在配置文件中也表示注釋某行  
  42. [root@jie1 ~]# sed -i '/ONBOOT/s/#//' test                  
  43.         #匹配ONBOOT的行,把#替換成空,即去掉#號,也一般用作去掉#注釋  
  44. #================執行以上sed命令之后文件顯示的內容====================  
  45. [root@jie1 ~]# cat test  
  46. anonymous_enable=YES  
  47. write_enable=YES  
  48. local_umask=022  
  49. xferlog_enable=YES  
  50. connect_from_port_20=NO  
  51. (root):x:1:1:(root):/(root):/bin/nologin  
  52. bin:x:1:1:tom:/tom:/stom/nologin  
  53. daemon:x:2:2:jerry:/sbin:/stom/nologin  
  54. daemon:x:2:2:jerry:/sbin:/stom/nologin  
  55. adm:x:3:4:boss:/var/adm:/sbin/nologin  
  56. lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin  
  57. Ethernet  
  58. #BOOTPROTO="dhcp"  
  59. HWADDR="00:0C:29:90:79:78"  
  60. ONBOOT="yes"  
  61. IPADDR=172.16.10.12  
  62. NETMASK=255.255.0.0  

sed引用變量:(在自動化shell腳本 中也經常會使用到變量)

第一種當sed命令里面沒有默認的變量時可以把單引號改成雙引號;

第二種當sed命令里面有默認的變量時,那自己定義的變量需要加單引號,且sed里面的語句必須用單引

[java] view plain copy
 
  1. [root@jie1 ~]# cat >> myfile << EOF  
  2. > hello world  
  3. > i am jie  
  4. > how are you  
  5. > EOF   #先生成一個文件  
  6. [root@jie1 ~]# cat myfile  
  7. hello world  
  8. i am jie  
  9. how are you  
  10. [root@jie1 ~]# name=li  
  11.          #定義一個變量,且給變量賦值  
  12. [root@jie1 ~]# sed -i "s/jie/$name/" myfile  
  13.          #把匹配jie的字符替換成變量的值  
  14. [root@jie1 ~]# cat myfile  
  15. hello world  
  16. i am li  
  17. how are you  
  18. [root@jie1 ~]# sed -i "$a $name" myfile  
  19.           #當sed命令也有默認變量時,在去引用自己定義的變量會出現語法錯誤  
  20. sed: -e expression #1, char 3: extra characters after command  
  21. [root@jie1 ~]# sed -i '$a '$name'' myfile  
  22.           #在引用自定義的變量時,sed語句必須用單引引住,然后把自定義的變量也用單引號引住  
  23. [root@jie1 ~]# cat myfile  
  24. hello world  
  25. i am li  
  26. how are you  
  27. li  
  28. [root@jie1 ~]#  

sed的其它高級使用:

1)把正在用sed操作的文件的內容寫到例外一個文件中

[java] view plain copy
 
  1. [root@jie1 ~]# cat test   #sed操作的文件中的內容  
  2. Ethernet  
  3. #BOOTPROTO="dhcp"  
  4. HWADDR="00:0C:29:90:79:78"  
  5. ONBOOT="yes"  
  6. IPADDR=172.16.10.12  
  7. NETMASK=255.255.0.0  
  8. [root@jie1 ~]# sed -i 's/IPADDR/ip/w ip.txt' test  
  9.        #把sed操作的文件內容保存到另外一個文件中,w表示保存,ip.txt文件名  
  10. [root@jie1 ~]# cat ip.txt  #查看新文件的內容  
  11. ip=172.16.10.12  
  12. [root@jie1 ~]#  

2)讀取一個文件到正在用sed操作的文件中

[java] view plain copy
 
  1. [root@jie1 ~]# cat myfile   #文件內容  
  2. hello world  
  3. i am li  
  4. how are you  
  5. li  
  6. [root@jie1 ~]# cat test  #將用sed操作的文件的內容  
  7. Ethernet  
  8. #BOOTPROTO="dhcp"  
  9. HWADDR="00:0C:29:90:79:78"  
  10. ONBOOT="yes"  
  11. IPADDR=172.16.10.12  
  12. NETMASK=255.255.0.0  
  13. [root@jie1 ~]# sed  -i '/Ethernet/r myfile' test  
  14.       #在匹配Ethernet的行,讀進來另一個文件的內容,讀進來的文件的內容會插入到匹配Ethernet的行后  
  15. [root@jie1 ~]# cat test  #再次查看用sed命令操作的行  
  16. Ethernet  
  17. hello world  
  18. i am li  
  19. how are you  
  20. li  
  21. #BOOTPROTO="dhcp"  
  22. HWADDR="00:0C:29:90:79:78"  
  23. ONBOOT="yes"  
  24. IPADDR=172.16.10.12  
  25. NETMASK=255.255.0.0  
  26. [root@jie1 ~]#  

sed的經典例子:

[java] view plain copy
 
  1. ##1)、處理以下文件內容,將域名取出並進行計數排序,如處理:  
  2. http://www.baidu.com/index.<a target="_blank" href="http://www.2cto.com/kf/qianduan/css/" class="keylink" style="border:none; padding:0px; margin:0px; color:rgb(51,51,51); text-decoration:none; font-size:14px">html</a>  
  3. http://www.baidu.com/1.html  
  4. http://post.baidu.com/index.html  
  5. http://mp3.baidu.com/index.html  
  6. http://www.baidu.com/3.html  
  7. http://post.baidu.com/2.html  
  8. 得到如下結果:  
  9. 域名的出現的次數 域名  
  10. 3 www.baidu.com  
  11. 2 post.baidu.com  
  12. 1 mp3.baidu.com  
  13. [root@localhost shell]# cat file | sed -e ' s/http:\/\///' -e ' s/\/.*//' | sort | uniq -c | sort -rn  
  14. 3 www.baidu.com  
  15. 2 post.baidu.com  
  16. 1 mp3.baidu.com  
  17. [root@codfei4 shell]# awk -F/ '{print $3}' file |sort -r|uniq -c|awk '{print $1"\t",$2}'  
  18. 3 www.baidu.com  
  19. 2 post.baidu.com  
  20. 1 mp3.baidu.com  
  21. ##2)、用grep結合sed取出網卡的ip地址  
  22. [root@jie1 ~]# ifconfig | grep -B1 "inet addr" |grep -v "\-\-" |sed -n -e 'N;s/eth[09].*\n.*addr:[09]{1,3}\.[09]{1,3}\.[09]{1,3}\.[09]{1,3}.*/\1 \2/p'  
 
 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM