打印文件的第一列
> awk '{print $1}' rumenz.txt
打印文件的前两列
> awk '{print $1,$2}' rumenz.txt
打印文件的最初一列
> awk '{print $NF}' rumenz.txt
打印文件的总行数
> awk 'END{print NR}' rumenz.txt
打印文件的第一行
> awk 'NR==1{print}' rumenz.txt
- NR 是指 awk 正在解决的记录位于文件中的地位(行号)
打印文件的第 3 行第 2 列
> sed -n '3,1p' rumenz.txt | awk '{print $2}'
删除空行
> awk 'NF' rumenz.txt
打印奇数行
> awk 'b=!b' rumenz.txt
打印文件按 #
宰割后, 行长度为 3 的所有行
> awk -F '#' 'if(NF==3){print}' rumenz.txt
- NF 是指 awk 正在解决的记录蕴含几个域(字段),这与域分隔符无关,默认为空
统计 Linux 零碎中每个用户所用的 shell
> cat /etc/passwd | awk -F ":" '{print $1" : "$7}'
用 awk 统计 linux 零碎中所有的用户数
> cat /etc/passwd | awk '{count++}END{print count}'
统计某个文件夹下文件所占的字节数
> ls -l | awk 'BEGIN{size=0}{size=size+$5}END{print size}'
统计某个文件夹下文件所占的字节数, 按 M 显示
> ls -l | awk 'BEGIN{size=0}{size=size+$5}END{print size}'
netstat 联合 awk 统计 TCP 连接数
> netstat -tunlp | awk '/^tcp/{++a[$6]}END{for(i in a) print i,a[i]}'
过滤空行
> awk '/^[^$]/ {print $0}' rumenz.txt
列运算
> cat 1.txt
1
2
3
求和
> cat 1.txt | awk '{a+=$1}END{print a}'
求平均值
> cat 1.txt | awk '{a+=$1}END{print a/NR}'
求列的最大值
> cat 1.txt | awk 'BEGIN{a=0}{if($1>a) a=$1 fi}END{print a}'
原文链接:https://rumenz.com/rumenbiji/…
微信公众号: 入门小站