大家好,很高兴再次与大家见面,我是全栈君。
今天我们要处理一个名为gamebill.txt的文本文件,目的是计算出3个人的累计消费金额,并根据金额大小进行排序。我们将使用awk的数组来完成这个任务。
![使用awk数组进行求和[通俗易懂]](https://img.php.cn/upload/article/001/503/042/175262916592690.jpg)
解决方案如下:
cat gamebill.txt | tail -n +2 | awk '{money[$1]+=$2} END{for (i in money) print i,money[i]}' | sort -k 2 -n这条命令的解释:
-
cat gamebill.txt:读取gamebill.txt文件的内容。 -
tail -n +2:跳过文件的第一行,从第二行开始处理。 -
awk '{money[$1]+=$2} END{for (i in money) print i,money[i]}':使用awk处理数据。money[$1]+=$2将每个人的消费金额累加到数组money中,END块在处理完所有行后输出结果。 -
sort -k 2 -n:根据第二列(即金额)的数值大小进行排序。
发布者:全栈程序员栈长,转载请注明出处:https://www.php.cn/link/d8c2a05e8270406dcdd260a088902cb5
原文链接:https://www.php.cn/link/c8377ad2a50fb65de28b11cfc628d75c










