awk编辑器

目录

工作原理

命令格式

普通格式

BEGIN格式

语句循环格式

awk常见的内建变量(可直接用)

按行打印行内容

统计行数量

按字段输出文本

[通过管道、双引号调用 Shell 命令](#通过管道、双引号调用 Shell 命令)


awk编辑器是一种流编辑器

工作原理

  • 逐行读取文本,默认以空格或tab键为分隔符进行分隔,将分隔所得的各个字段保存到内建变量中,并按模式或者条件执行编辑命令。
  • awk信息的读入也是逐行读取的,执行结果可以通过print的功能将字段数据打印显示。
  • 在使用awk命令的过程 中,可以使用逻辑操作符"&&"表示"与"、"||"表示"或"、"!"表示"非";还可以进行简单的数学运算,如+、-、*、/、%、^分别表示加、减、乘、除、取余和乘方。

命令格式

普通格式

awk 选项 '模式或条件 {操作}' 文件 1 文件 2 ... #对文件1,文件2进行操作
awk -f 脚本文件 文件 1 文件 2 ... #用脚本对对文件1,文件2进行操作

BEGIN格式

awk 'BEGIN {...}; 条件{...}; END {...}' 文件

  • BEGIN {...} 表示处理文件前要执行的操作
  • 条件{...} 表示对匹配满足指定条件的文件行内容要执行的操作
  • END {...} 表示处理完文件所有行内容后要执行的操作

语句循环格式

awk '{控制语句条件 {操作}}' 文件
awk 'if(条件表达式) {操作}' 文件 #行内容满足if的条件则执行操作
awk '变量=条件表达式?值1:值2; {操作}' 文件

#行内容是否条件表达式,如果条件成立则变量取值1,条件不成立则变量取值2
awk 'BEGIN{执行循环前的操作; while("命令" | getline) 每次循环的操作; 执行循环完后的操作}'#使用while循环对每行内容执行操作

awk常见的内建变量(可直接用)

  • FS:列分割符。指定每行文本的字段分隔符,默认为空格或制表位。与"-F"作用相同
  • NF:当前处理的行的字段个数。
  • NR:当前处理的行的行号(序数)。
  • $0:当前处理的行的整行内容。
  • $n:当前处理行的第n个字段(第n列)。
  • **FILENAME:**被处理的文件名。
  • **RS:**行分隔符。awk从文件上读取资料时,将根据RS的定义把资料切割成许多条记录,而awk一次仅读入一条记录,以进行处理。预设值是'\n'
  • FNR: awk当前读取的记录数,其变量值小于等于NR(比如当读取第二个文件时,FNR是从0开始重新计数,而NR不会)。
    NR==FNR:用于在读取两个或两个以上的文件时,判断是不是在读取第一个文件

按行打印行内容

awk '{print $0}' 文件 #打印文件里所有内容

awk 'NR=1{print $0}' 文件 #打印文件里第一行内容

awk 'NR=1,NR=3{print $0}' 文件 #答应文件里第一行到第三行的内容

awk 'NR>=80{print $0}' 文件 #打印文件里80行以后的内容

awk '(NR>=70)&&(NR<=80){print $0}' 文件 #打印文件70行到80行的内容

awk '(NR>=70)||(NR<=80){print $0}' 文件 #打印文件70行和80行的内容

awk '(NR<=3)||(NR>=80){print $0}' 文件 #打印文件前3行和后80行的内容

awk '(NR%)==1 {print $0}' 文件 #打印文件奇数行

awk '{print $0;getline}' 文件 #打印文件奇数行 getline为跳到下一行

awk '(NR%)==0 {print $0}' 文件 #打印偶数行

awk '{getline;print $0}' 文件 #打印偶数行 getline为跳到下一行

awk '/root/{print $0}' 文件 #打印包含root的行内容

awk '/\/bin\/bash$/{print $0}' 文件 #打印以/bin/bash结尾的行内容

统计行数量

awk 'BEGIN {X=0}; /bash$/ {x++};END {print x}' 文件 #统计以bash结尾的行数

awk 'BEGIN {n=0;while("who" | getline)n++; print $n}'#统计who命令的有多少行

按字段输出文本

默认以空格或tab键为分隔符进行分隔

awk -F ":" '{print $3}' 文件 #输出每行中(以:分隔)的第3个字段
awk -F ":" '{print $1,$3}' 文件 #输出每行中(以:分隔)的第1、3个字段

awk -F ":" '$3<5{print $1,$3}' 文件

#输出每行(以:分隔)第3个字段的值小于5的第1、3 个字段内容

awk -F ":" '!($3<200){print 0}' 文件** #输出每行第3个字段的值不小于200的行 **awk -F ":" '/bash/ {print $1":"$3}' 文件

#输出每行以bash结尾的,并且以:分隔的第 一个字段和第三个字段,最后以:分隔输出内容

awk -F ":" '$3<5{print $1,3,NF}' 文件

#输出每行(以:分隔)第3个字段的值小于5的第1、3个字段和最后一个字段内容

awk -F ":" '$3<5{print NR,$0}' 文件#打印行号,同行输出

awk -F ":" '$3<5{print NR} $3<5{print $0}' 文件#打印行号,不同行输出

awk -F ":" '$3~"bash"{print $0}' 文件

#输出每行中(以:分隔)的第3个字段包含bash的行内容 ~ 表示包含的意思

通过管道、双引号调用 Shell 命令

echo $PATH | awk 'BEGIN{RS=":"};END{print NR}'

#统计以冒号分隔的文本段落数,END{}语句块中,往往会放入打印结果等语句
awk -F: '/bash$/{print | "wc -l"}' /etc/passwd

#调用 wc -l 命令统计使用 bash 的用户个数,等同于 grep -c "bash$" /etc/passwd
free -m | awk '/Mem:/ {print int($3/($3+$4)*100)"%"}' #查看当前内存使用百分比
top -b -n 1 | grep Cpu | awk -F ',' '{print $4}' | awk '{print $1}'

#查看当前CPU空闲率,(-b -n 1 表示只需要1次的输出结果)
date -d "$(awk -F "." '{print $1}' /proc/uptime) second ago" +"%F %H:%M:%S"

#显示上次系统重启时间
awk 'BEGIN {n=0 ; while ("w" | getline) n++ ; {print n-2}}'

#调用w命令,并用来统计在线用户数
awk 'BEGIN {"hostname" | getline ; {print $0}}' #调用 hostname,并输出当前的主机名

相关推荐
pakano2 小时前
VSCode 间距太小
ide·vscode·编辑器
wongHome8 小时前
VSCode 如何选中包含某个字母的所有行
vscode·编辑器
Strive_Sun11 小时前
使用 vscode 调试 nodejs 代码
ide·vscode·编辑器
程楠楠&M12 小时前
node.js路由
node.js·编辑器·vim
m0_6278275214 小时前
不需要双手离开键盘 vscode
ide·vscode·编辑器
tlog15 小时前
【vim】vim怎么把某一列内容复制到另一列
linux·编辑器·vim
知野小兔1 天前
【Vscode】不同系统快捷键
ide·vscode·编辑器
Gene_20221 天前
vscode + ROS 配置快捷编译
ide·vscode·编辑器
lin zaixi()1 天前
VSCode 下载 & 安装
ide·vscode·编辑器
ZHOUPUYU1 天前
最新‌VSCode保姆级安装教程(附安装包)
c语言·开发语言·c++·ide·windows·vscode·编辑器