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,并输出当前的主机名

相关推荐
ONLYOFFICE11 小时前
【技术教程】如何将ONLYOFFICE文档集成到使用Spring Boot框架编写的Java Web应用程序中
java·spring boot·编辑器
Blue桃之夭夭14 小时前
Visual Studio Code设置个性化背景教程
ide·vscode·编辑器
EQ-雪梨蛋花汤1 天前
【Unity笔记】Unity 编辑器扩展:打造一个可切换 Config.assets 的顶部菜单插件
unity·编辑器·游戏引擎
byte轻骑兵2 天前
365 天技术创作手记:从一行代码到四万同行者的相遇
ide·vscode·编辑器
奥特曼打小白2 天前
Visual Studio Code的第一次安装
ide·vscode·编辑器
凯哥Java2 天前
适应新环境:Trae编辑器下的IDEA快捷键定制
java·编辑器·intellij-idea
EveryPossible2 天前
如何终止画图
linux·编辑器·vim
极客柒2 天前
Unity 塔防自用可视化路点寻路编辑器
unity·编辑器·游戏引擎
歪歪1003 天前
Qt Creator 打包应用程序时经常会遇到各种问题
开发语言·c++·qt·架构·编辑器
战南诚3 天前
前端开发vscode插件 - live server
ide·vscode·编辑器