关于linux:linux之awk使用技巧

39次阅读

共计 969 个字符,预计需要花费 3 分钟才能阅读完成。

打印文件的第一列

> 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/…
微信公众号: 入门小站

正文完
 0