2019.4.19|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第一行的第一列和第二列
【2019.4.19|2019.4.19 三剑客awk】[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磁盘管理

    推荐阅读