2019.4.19 三剑客awk

2019.4.19

1. 查看/etc/hosts里面的644


[root@huahua ~]# stat /etc/hosts | sed -n 4p | sed 's#^.*s: (0##g' | sed 's#/-.*$##g'

644

[root@oldboyedu59 ~]# stat /etc/hosts |sed -n 4p |sed -r 's#^.*\(0([0-9]+)/.*$#\1#g'644

2.awk格式

sed ‘找谁干啥’

awk  ‘找谁{干啥}’    //{}以外是条件,{}以内是内容

NR    行号   ‘/oldboy/’

$1    取列

$0    整行内容

$NF    最后1列

NF-1    倒数第2列

-F    指定分隔符 ‘{print$1}’

比大小

比大小不用print

>

<

>=

<=

==    等于号

!=    不等于号

3.取huahua.txt的第三行

[root@huahua ~]# awk 'NR==3' huahua.txt    

13

4.找huahua.txt中含1的行

[root@huahua ~]# awk '/1/' huahua.txt    

11

12

13

14

15

5.查看huahua.txt的每一行的行号

[root@huahua ~]# awk '{print NR $0}' huahua.txt    //$0代表所有列,逗号代表空格


可以看到行号和内容连在一起了                    加一个,会发现行号和内容之间有空格




[root@oldboyedu59 /oldboy]# awk  '{print $1"@@@"$3}' oldboy.txt   //老师

I@@@oldboy

I@@@linux.

@@@

I@@@badminton

my@@@is

our@@@is

my@@@is

@@@

not@@@

my@@@am

oldboy@@@oldboy


6.指定新的分隔符(菜单),指定分隔符用F ,默认分隔符是空格,只要是[]里面的内容,正则认为是一样的

(1)显示huahua.txt第一行的第一列和第二列

[root@huahua ~]# awk 'NR==1{print $1,$2}' huahua.txt    //不知道分隔符,默认就是空格

11 xixi

(2)显示huahua.txt第2行第1列第3列

[root@huahua ~]# awk -F',' 'NR==2{print $1,$3}' huahua.txt    //逗号是新分隔符

12 zhizhi

(3)显示oldboy.txt的第4行的第1列 第2列和第4列

[root@huahua ~]# awk 'NR==4' oldboy.txt | awk '{print $1,$2,$4}'   

[root@huahua ~]# awk -F'[, ]' 'NR==4{print $1,$2,$4}' oldboy.txt  //指定逗号和空格是分隔符 

huahua jinijin xiaxia

(4)显示行号为1的这一行的所有内容

[root@huahua ~]# awk 'NR==1{print NR,$0}' huahua.txt    //$0代表所有列,$1代表1列

1 11

(5)查看ip a s ens33中的192.168.10.142

 

[root@huahua ~]# ip a s ens33 | awk -F'[ /]' 'NR==3{print $6}'    //前面有空格,1个空格代表一列,所以是$6

192.168.10.142

[root@huahua ~]# ip a s ens33 | awk -F'[ /]+' 'NR==3{print $3}'    //+ 连续出现1次或者一次以上的字符

192.168.10.142

[root@huahua ~]# ip a s ens33 |sed -n '3p'| sed 's#^.*t ##g' | sed 's#/.*$##g'

192.168.10.142

[root@huahua ~]# ip a s ens33 |sed -n 3p | sed -r 's#^.*t (.*)/.*$#\1#g'

192.168.10.142

7.比大小的时候不用print

(1)显示/etc/passwd文件列大于999

[root@huahua ~]# awk -F":" '$3>999' /etc/passwd     

xxn:x:1000:1000:xxn:/home/xxn:/bin/bash

huahua:x:1001:1001::/home/huahua:/bin/bash

(2)显示/etc/passwd中第4列大于0 并且 第4列小于1000的行

[root@huahua ~]# awk -F':' '$4<1000&&$4>0' /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

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

(3)查看使用率大于1的

[root@huahua ~]# df -h | awk '$5>1'    /


(4)用逗号分列,取第1列

[root@huahua ~]# cat xin.txt

i am lidao,my qq is 123456

[root@huahua ~]# awk -F',' '{print $1}' xin.txt    

i am lidao

以逗号和空格分列,取第3列和第7列

[root@huahua ~]# awk -F'[, ]' '{print $3,$7}' xin.txt   

lidao 123456

6.NF    最后一列  

[root@huahua ~]# echo {1..20..5}

1 6 11 16

(1)查看最后一列

[root@huahua ~]# echo {1..20..5} | awk '{print $NF-1}'

15

(2)先乘除,后加减,有括号先执行括号里面的

[root@huahua ~]# echo {1..20..5} | awk '{print $(NF-1)}'

11


7.wc 计算字数

 -l 统计行数

[root@huahua ~]# wc -l /etc/passwd    //查看/etc/passwd有多少行

23 /etc/passwd

[root@huahua ~]# ls /etc/ | wc -l    //查看/etc下面有多少个文件

190

[root@huahua ~]# man awk | wc -l    //查看man awk有多少行,显示有1993行



下次:

awk 如何使用正则 某一列中包含什么内容

如何计算1+...+100

seq 100 |awk

其他取出网卡ip地址方式


Linux权限体系

对文件对目录rwx含义


Linux用户管理

定时任务

Linux磁盘管理

你可能感兴趣的:(2019.4.19 三剑客awk)