[svc]sed&awk過濾行及sed常用例子


- sed過濾行
sed '2p'
sed '2,5p'
sed '2p;3p;4p'

- awk過濾行
awk 'NR==2'
awk 'NR>=2 && NR <=3'
awk 'NR==2||NR==3||NR==4'

- awk條件過濾
awk '{if($3>10) print $0}'

過濾某1行

sed過濾第2行

[root@n1 ~]# sed -n '2p' /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin

awk過濾第2行

[root@n1 ~]# awk 'NR==2' /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin

過濾2<i<4行

sed過濾2<i<4行

[root@n1 ~]# sed -n '2,4p' /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin

awk過濾2<i<4行

[root@n1 ~]# awk -F 'NR>=2 && NR<=4' /etc/passwd
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin

過濾>=20行

[root@n1 ~]# awk 'NR>=20' /etc/passwd 
ntp:x:38:38::/etc/ntp:/sbin/nologin
mysql:x:1000:1000::/home/mysql:/sbin/nologin

第1 3 5行

sed過濾第1 3 5行

[root@n1 ~]# sed -n '1p;3p;4p' /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin

awk過濾第1 3 5行

[root@n1 ~]# awk "NR==1||NR==3||NR==5" /etc/passwd
root:x:0:0:root:/root:/bin/bash
daemon:x:2:2:daemon:/sbin:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

第3列>3 第3列<15的行

awk過濾: 3<第3列<15

[root@n1 ~]# cat /etc/passwd|awk -F ':' '{if($3>10 && $3<15) print $0}'
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin

另一個例子: 如何顯示文本file.txt中第二大列大於56789的行?

awk -F "," '{if($2>56789){print $0}}' file.txt

sed常用例子

  • 獲取文件除后綴外文件名
filename_exclude_suffix=`echo $1|sed 's#\.[^.]*$##'`

$ echo a.b.c.bin | sed 's/\.[^.]*$//'
a.b.c
  • 給文件某一樣行首加#
- 如常用注釋crontab
sed -i 's/^/#/' /var/spool/cron/root
  • 替換行(修改配置)
sed -i "/ServerID/c ServerID = ${server_id}" php.ini


免責聲明!

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



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