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 (降序)