Linux awk命令常见使用方法介绍
Linux awk命令常见使用方法介绍
By:授客 QQ:1033553122
awk运行方式有三种,其中常用的为命令行方式
awk [-F field_separator] '{pattern + action}' input_file(s)
其中,其中 pattern 表示awk需要查找的内容,由符号//包围,形如 /^shouke/,而 action 是在找到匹配内容时所执行的一系列命令,[-F field_separator]可选,input-file(s) 是待处理的文件。
通常,awk是以文件的一行为处理单位的。awk每接收文件的一行,然后执行相应的命令来处理文本。
在awk中,文件的每一行中,由域分隔符(field_separator,默认为空格)分开的每一项称为一个域。
[root@localhost ~]# touch testfile
[root@localhost ~]# vim testfile
id name sex addr hobby
1 name:shouke sex:男 addr:深圳 hobby:music
2 name:laiyu sex:女 addr:云南 hobby:none
例子1:不指定分割符,从文件读取数据(awk '{action}' input_file(s)
[root@localhost ~]# awk '{print $1, $2}' testfile
id name
1 name:shouke
2 name:laiyu
说明:awk工作流程是这样的:读入由换行符'\n'分割的一条记录,然后将记录按指定的域分隔符划分域,填充域($0则表示所有域,$1表示第一个域,$n表示第n个域),接着读取下一条记录,重复前面的操作。默认域分隔符是"空白键" 或 "tab键"
例子2:指定分隔符,从文件读取数据(awk -F field_separator '{action}' input_file(s)
[root@localhost ~]# awk -F ':' '{print $1, $2}' testfile
id name sex addr hobby
1 name shouke sex
2 name laiyu sex
例子3:从命令输出结果读取数据
[root@localhost ~]# cat testfile | awk '{print $2, $3}'
name sex
name:shouke sex:男
name:laiyu sex:女
例子4:格式化输出
[root@localhost ~]# cat testfile | awk '{print $2"\t"$3}'
name sex
name:shouke sex:男
name:laiyu sex:女
例子5: 指定初始操作和结尾操作
[root@localhost ~]# cat testfile | awk 'BEGIN {print "first"} {print $2,$3} END {print "finally"}'
first
name sex
name:shouke sex:男
name:laiyu sex:女
finally
例子6:指定pattern模式(awk [-F field_separator] '{pattern}' input_file(s)
[root@localhost ~]# cat testfile | awk '/laiyu/'
2 name:laiyu sex:女 addr:云南 hobby:none
说明:
1.例子为搜索文件中所有包含pattern即字符串“laiyu”的行记录,仅匹配了pattern(例中为laiyu)的行才会执行action(这里没有指定action,默认输出每行的内容)。
2.搜索支持正则,例如找laiyu开头的: cat testfile | awk '/^laiyu/'
例7:指定pattern+action模式(awk [-F field_separator] '{pattern+action}' input_file(s) [root@localhost ~]# cat testfile | awk '/laiyu/{print $2, $3}'
name:laiyu sex:女
例8:printf格式化输出
[root@localhost home]# cat testfile | awk '{print $2}' | awk -F ':' '{printf("newname:%5s, oldname:%5s\n", $2, $2)}'
newname: , oldname:
newname:shouke, oldname:shouke
newname:laiyu, oldname:laiyu
newname: , oldname:
例9:自定义变量
[root@localhost home]# cat testfile | awk 'BEGIN {num=0;}{num=num+1;} END{print "rows of record have been read is: " num}'
rows of record have been read is: 4
说明:例中自定义了一个变量:num,初始值为0。action{}中可以有多条语句,每条以;号隔开。
例10:使用内置变量
[root@localhost home]# cat testfile | awk '{print "rows of record have been read is: " NR}'
rows of record have been read is: 1
rows of record have been read is: 2
rows of record have been read is: 3
rows of record have been read is: 4
说明:处理$0等变量,awk还有其它内置变量,比如 NR--读取的记录数,FILENAME--awk浏览的文件名
除此之外,action {}中还可使用循环语句,判断语句等
作者:授客
微信/QQ:1033553122
全国软件测试QQ交流群:7156436
Git地址:https://gitee.com/ishouke
友情提示:限于时间仓促,文中可能存在错误,欢迎指正、评论!
作者五行缺钱,如果觉得文章对您有帮助,请扫描下边的二维码打赏作者,金额随意,您的支持将是我继续创作的源动力,打赏后如有任何疑问,请联系我!!!
微信打赏
支付宝打赏 全国软件测试交流QQ群
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· 【.NET】调用本地 Deepseek 模型
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· DeepSeek “源神”启动!「GitHub 热点速览」
· 我与微信审核的“相爱相杀”看个人小程序副业
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库