深入解析 Linux 上使用的 awk 命令的细节
awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。 awk有3个不同版本: awk、nawk和gawk,未作特别说明,一般指gawk,gawk 是 AWK 的 GNU 版本。 awk其名称得自于它的创始人 Alfred Aho 、Peter Weinberger 和 Brian Kernighan 姓氏的首个字母。实际上 AWK 的确拥有自己的语言: AWK 程序设计语言 , 三位创建者已将它正式定义为“样式扫描和处理语言”。它允许您创建简短的程序,这些程序读取输入文件、为数据排序、处理数据、对输入执行计算以及生成报表,还有无数其他的功能。 一、选项参数说明 awk是一种处理文本文件的语言,我们可以使用awk --help查看一下它的选项参数。 二、基本用法 1、行匹配语句,此处awk后只能跟单引号,格式如下: awk '{匹配的内容}' 匹配的文件名称 例如: 现有如下测试文件test: 使用如下命令输出文中每行的1、4项内容: awk '{print $1,$4}' test 也可以添加如下内容使其格式化输出: awk '{printf "%-8s %-10s/n",$1,$4}' test 2、指定分隔符 awk '{printf "%-8s %-10s/n",$1,$4}' test 例如: 有如下test文件: 执行如下命令,使用逗号分割输出每行的第一、二项内容: awk -F, '{print $1,$2}' test 也可以使用内建变量,格式如下: awk 'BEGIN{FS=","} {print $1,$2}' test 对于使用多个分隔符,首先使用空格分割,然后再使用其他分割符进行分割: awk -F '[ ,]' '{print $1,$2,$4}' test 3、设置变量 awk -v 例如: 现有如下数据: 执行如下命令,每行第一项加1: awk -va=1 '{print $1,$1+a}' test 也可以使用如下命令设置多个变量: awk -va=1 -vb=s '{print $1,$1+a,$1b}' test 4、通过awk脚本来运行awk命令 awk -f awk脚本 文件名 (编辑:银川站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |