Linux命令----sed和awk


sed


-n :加上-n參數後,只有經過sed特殊處理的哪一行或者動作纔會被列出來。


動作說明:[n1,n2[function]]

function :

     a:新增,a的後面可以接字符串,而這些字符串會在新的一行出現(目前的下一行)

     c:取代,c的後面可以接字符串,這些字符串可以取代 n1,n2 之間的行

     d:刪除,d後面通常不接任何東西;

      i:插入,i後面可以接字符串,而這些字符串會出現在新的一行(目前的上一行)

     p:列印,

     s:取代,可以直接進行取代的工作,通常這個s的動作可以搭配正則表示法

[root@localhost ~]# nl passwd | sed  '2,5d'     #刪除文件2-5行
[root@localhost ~]# nl passwd | sed -n '2p'    #顯示文件第二行 加-n
     2     bin:x:1:1:bin:/bin:/sbin/nologin
[root@localhost ~]# nl passwd | sed  '2p'        #不加-n 會顯示全部文件
[root@localhost ~]# nl passwd | sed  '2a lulalaldemaxiya'    #在第二行後面追加一行
[root@localhost ~]# nl passwd | sed  '2i lulalaldemaxiya'     #在第二行前面追加一行
[root@localhost ~]# nl passwd | sed '2,5c No 2-5 number'  #將第2-5行取代爲No 2-5 number
1     root:x:0:0:root:/root:/bin/bash
No 2-5 number
6     sync:x:5:0:sync:/sbin:/bin/sync
[root@localhost ~]# nl passwd | sed -n '/root/p'      #顯示匹配到的行


數據的搜尋並替換

[root@localhost ~]# ifconfig | sed -n '2p'|sed 's/^.*addr://'|sed 's/ Bca.*//'   #ifconfig只顯示ip
192.168.3.139


多點編輯

[root@localhost ~]# nl /etc/passwd|sed -e '3,$d' -e 's/bash/blueshell/'
     1     root:x:0:0:root:/root:/bin/blueshell
     2     bin:x:1:1:bin:/bin:/sbin/nologin
刪除/etc/pass 第三行到末尾的數據,並把bash替換爲blueshell
-e 表示多點編輯




awk

[root@localhost ~]# last -n 5 |awk '{print $1}'
root
reboot
root
reboot
root

awk工作流程是這樣的,讀入有‘\n’換行符分割的一條記錄,然後將記錄按指定的域分割符劃分域,$0

則表示所有域,$1表示第一個域,$n表示第n個域。默認域分隔符是“空白鍵”或 “【tab】建”,所以$1

表示登錄用戶,$3表示登錄用戶ip

[root@localhost ~]# cat passwd | awk -F ':' '{print $1 "\t" $7}'
root     /bin/bash
bin     /sbin/nologin
daemon     /sbin/nologin
adm     /sbin/nologin
lp     /sbin/nologin


-F 指定域分割符爲‘;’  並輸出  賬戶 和 賬戶對應的shell。

[root@localhost ~]# head -n 5 passwd | awk -F ':' 'BEGIN{print "name,shell"} {print $1 "," $7} END{print "end,line"}'

name,shell
root,/bin/bash
bin,/sbin/nologin
daemon,/sbin/nologin
adm,/sbin/nologin
lp,/sbin/nologin
end,line
[root@localhost ~]# awk -F : '{print "filename:",FILENAME",linenumber:"NR ",columns:"NF ",linecontent:" $0}' passwd

顯示文件passwd 文件名FILENAME 已讀的記錄數(行數)NR    瀏覽記錄的域的個數(列數)NF 顯示完整的行內信息$0
[root@localhost ~]# head -n 5 passwd | awk -F : '{count++;print $1;} END{print "user count is ",count}'
 

[root@localhost ~]# ls -l | awk 'BEGIN{size=0;}{size=size+$5;} END{print "[end]size = ",size}'

[root@localhost
 ~]# ls -l | awk 'BEGIN{size =0;print "[start]size 
is",size}{if($5!=4096) {size=size+$5;}} END{print "[end]size 
is",size/1024/1024,"M"}'

[root@localhost ~]# awk -F : 'BEGIN{count=0;}{name[count]=$1;count++;};END{for(i=0;i<NR;i++) print i,name[i]}' passwd

去重  |sort(升序)| uniq -c |  sort -r (降序)





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章