7.5 9.6-9.7

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了7.5 9.6-9.7相关的知识,希望对你有一定的参考价值。

9.6 awk()

 

-F 指定分隔符,打印每一行第一段

[[email protected] awk]# awk -F ':' '{print $1}' test.txt

打印每一行所有的段

[[email protected] awk]# awk -F ':' '{print $0}' test.txt

打印文件所有内容

[[email protected] awk]# awk '{print $0}' test.txt

 

若不使用-F指定分隔符,则将把空格或空白字符当做分隔符打印

[[email protected] awk]# cat 11.txt

aa bb cc

dd ee ff

gg vv hh

[[email protected] awk]# awk '{print $1}' 11.txt

aa

dd

gg 此时以空格作为分隔符

 

打印多段内容

[[email protected] awk]# awk '{print $1,$3}' 11.txt

aa cc

dd ff

gg hh

在显示的结果中加入符号(符号需要引起来)

[[email protected] awk]# awk '{print $1"#"$3}' 11.txt

aa#cc

dd#ff

gg#hh

 

匹配包含oo的行

[[email protected] awk]# awk '/oo/' test.txt

root:x:0:0:root:/root:/bin/bash

lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nologin

postfix:x:89:89::/var/spool/postfix:/sbin/nologin

匹配第一段包含oo的行

[[email protected] awk]# awk -F ':' '$1 ~ /oo/' test.txt

root:x:0:0:root:/root:/bin/bash

匹配第一段至少有一个o的行

[[email protected] awk]# awk -F ':' '$1 ~ /o+/' test.txt

root:x:0:0:root:/root:/bin/bash

daemon:x:2:2:daemon:/sbin:/sbin/nologin

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

operator:x:11:0:operator:/root:/sbin/nologin

nobody:x:99:99:Nobody:/:/sbin/nologin

systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin

polkitd:x:999:997:User for polkitd:/:/sbin/nologin

postfix:x:89:89::/var/spool/postfix:/sbin/nologin

chrony:x:998:996::/var/lib/chrony:/sbin/nologin

匹配第一段至少有2o的行

[[email protected] awk]# awk -F ':' '$1 ~ /oo+/' test.txt

root:x:0:0:root:/root:/bin/bash

匹配root的行打印第1和第3段,匹配hyc的行打印第6和第7

[[email protected] awk]# awk -F ':' '/root/ {print $1,$3} /hyc/ {print $6"#"$7}' test.txt

root 0

operator 11

/home/hyc/#/bin/bash

 

$0表示一行的所有内容,即每一段

 

匹配第3段等于0的行并打印该行的第1

[[email protected] awk]# awk -F ':' '$3==0 {print $1}' test.txt

Root

匹配第3段等于0的行并打印该行

[[email protected] awk]# awk -F ':' '$3==0' test.txt

root:x:0:0:root:/root:/bin/bash

= 表示赋值,为某个变量赋值时使用

== 表示等号

 

匹配第3段大于等于1000的行并打印该行

[[email protected] awk]# awk -F ':' '$3>=1000' test.txt

hyc1:x:1000:1000:/home/hyc1/:/bin/bash

在和数字比较时,若把比较的数字用双引号引起来后,那么awk不会认为是数字,而认为是字符,不加双引号则认为是数字

[[email protected] awk]# awk -F ':' '$3>="1000"' test.txt

daemon:x:2:2:daemon:/sbin:/sbin/nologin

adm:x:3:4:adm:/var/adm:/sbin/nologin

lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

sync:x:5:0:sync:/sbin:/bin/sync

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

halt:x:7:0:halt:/sbin:/sbin/halt

mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

 

匹配第7段不是/sbin/nologin的行并打印匹配行

[[email protected] awk]# awk -F ':' '$7!="/sbin/nologin" {print $0}' test.txt

root:x:0:0:root:/root:/bin/bash

sync:x:5:0:sync:/sbin:/bin/sync

shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

halt:x:7:0:halt:/sbin:/sbin/halt

hyc:x:999:999::/home/hyc/:/bin/bash

hyc1:x:1000:1000:/home/hyc1/:/bin/bash

!= 代表不等于;

匹配字符串时需要加双引号;

 

9.7 awk(下)


以上是关于7.5 9.6-9.7的主要内容,如果未能解决你的问题,请参考以下文章

9.6/9.7 awk

9.6/9.7 awk

六周第三次课(1月17日) 9.6/9.7 awk

9.6 ---- 9.7

9.6/9.7 awk

3.14 9.6-9.7听课笔记