我有这种格式的数据
a1 1901 4
a1 1902 5
a3 1902 6
a4 1902 7
a4 1903 8
a5 1903 9
我想计算第一列中每个实体的累积分数(第三列)。所以我试着做一个哈希,我的代码看起来像这样:
use strict;
use warnings;
use Data::Dumper;
my $file = shift;
open (DATA, $file);
my %hash;
while ( my $line = <DATA> ) {
chomp $line;
my ($protein, $year, $score) = split /\s+/, $line;
push @{ $hash{$protein}{$year} }, $score;
}
print Dumper \%hash;
close DATA:
输出看起来像这样
$VAR1 = {
'a3' => {
'1902' => [
5
]
},
'a1' => {
'1902' => [
6
],
'1901' => [
4
]
},
'a4' => {
'1903' => [
8
],
'1902' => [
7
]
},
'a5' => {
'1903' => [
9
]
}
};
我现在想访问第 1 列 (a1,a2,a3) 中的每个实体并添加分数,因此所需的输出将是这样的:
a1 1901 4
a1 1902 9 # 4+5
a3 1902 6
a4 1902 7
a4 1903 16 # 7+9
a5 1903 9
但是我无法想出如何在循环中访问创建的哈希值以添加值?