2019-04-19

awk格式
sed '找谁干啥'
awk '找谁{干啥}'
老男孩教育-awk命令执行过程-完整
https://www.processon.com/view/link/5becee35e4b0d74dc540e690

[root@oldboyedu59 /oldboy]# awk '/oldboy/' lidao.txt
101,oldboy,CEO

echo 'I am lidao,my qq is 918391635' >/oldboy
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磁盘管理

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容