提高文本处理效率:精通awk命令中的$NF
在AWK
编程语言中,$NF
是一个特定的变量,用于引用当前处理记录中的最后一个字段值。这里的NF
是AWK
的一个内置变量,表示当前记录所含字段的数量。通过使用$NF
,可以直接获取到与NF
数值相对应的那个字段的具体内容。
示例使用
以下文件data.txt
,为测试文件,内容如下:
Alice 30 Engineer
Bob 25 Designer
Charlie 35 Manager
1、您可以使用awk
命令打印每一行的最后一个字段(职位名称),执行如下命令:
awk '{ print $NF }' data.txt
执行上述命令后,输出结果如下所示:
root@databases:~# awk '{ print $NF }' data.txt
Engineer
Designer
Manager
在
data.txt
文件的每一行中,awk
根据空白(默认行为)将该行拆分为字段。对于第一行,NF为3(代表
Alice
、30
、Engineer
),因此$NF指的是Engineer
。对于第二行,它指的是设计师,对于第三行,它指的是经理。
2、打印带有行号的最后一个字段,可以执行如下命令:
awk '{ print NR ": " $NF }' data.txt
执行上述命令后,输出结果如下所示:
root@databases:~# awk '{ print NR ": " $NF }' data.txt
1: Engineer
2: Designer
3: Manager
3、检查最后一个字段是否与特定值匹配,可以执行如下命令:
awk '$NF == "Manager" { print $1 }' data.txt
执行上述命令后,输出结果如下所示:
root@databases:~# awk '$NF == "Manager" { print $1 }' data.txt
Charlie
此命令打印最后一个字段为
Manager
的名称。
4、对第二个字段进行总和,但仅打印最后一个字段,可以执行如下命令:
awk '{ sum += $2 } END { print "Total age is:", sum; print "Last field in last line is:", $NF }' data.txt
执行上述命令后,输出结果如下所示:
root@databases:~# awk '{ sum += $2 } END { print "Total age is:", sum; print "Last field in last line is:", $NF }' data.txt
Total age is: 90
Last field in last line is: Manager
请注意,在该案例中,
$NF
指的是awk
处理的最后一行的最后一个字段。
当您在处理每个人字段数量都不相同的数据时,$NF
变量就显得特别有帮助了。它能够让您灵活地获取到最后一个字段的信息。
推荐阅读
本文是原创文章,采用 CC BY-NC-ND 4.0 协议,完整转载请注明来自 攻城狮小林
评论
匿名评论
隐私政策
你无需删除空行,直接评论以获取最佳展示效果