使用AWK的group-by功能可以轻松地实现重新排列数据文件并提供子总计和总计。
示例如下:
假设我们有一个包含以下字段的数据文件:
Employee|Department|Salary
John|Sales|5000
Sara|Sales|6000
Bob|Marketing|7000
Tom|Marketing|8000
我们想要按部门重新排列数据,输出每个部门的总工资,以及所有部门的总工资。
使用AWK的group-by功能,我们可以这样实现:
awk -F '|' 'BEGIN {print "Department|TotalSalary"} {dept[$2] += $3; total += $3} END { for (d in dept) {print d "|" dept[d]} print "Total|"total}' datafile.txt
在上述代码中,“-F”选项设置为“|”,以便我们可以像数组一样访问每个字段。
接下来,我们使用group-by功能将数据按部门进行分组,并使用数组“dept”来计算部门工资总额以及所有部门的总工资。
在最后一步中,我们使用一个循环遍历数组“dept”,输出每个部门的工资总额。
最后,我们输出所有部门的总工资。
输出结果如下:
Department|TotalSalary
Marketing|15000
Sales|11000
Total|26000
以上就是使用AWK的group-by功能对数据文件进行重排,并提供子总计和总计的解决方法。