我有一个我想要阅读的文件,每个位置都有可变数量的ID,如下所示:
loc1 id1 id4 id5 id9
loc2 id2
loc3 id1 id11 id23
我想将其存储如下locs(loc)= {属于该位置的所有ID} 以后,当我读到另一个文件时,我可以做类似
的事情if (grep id, locs(loc)){do something}
我尝试使用哈希来做到这一点,但这不起作用。我试过了:
open my $loclist, '<', $ARGV[0];
my %locs;
while (<$loclist>) {
my @loclist_rec = split;
my $loclist_loc = @rlist_rec[0];
$locs{$loclist_loc} = @loclist_rec;
}
但这不起作用。 我是perl的新手,仍然试图了解不同的数据类型。
有什么想法吗?非常感谢!
答案 0 :(得分:6)
这应该做你想要的。
#!/usr/bin/perl
use strict;
use warnings;
use Data::Dumper;
open my $loclist, '<', "test.txt" or die $!;
my %locs;
while (<$loclist>) {
my ($loclist_loc, @loclist_rec) = split;
$locs{$loclist_loc} = \@loclist_rec;
}
print Dumper \%locs;
输出:
$ perl test.pl
$VAR1 = {
'loc2' => [
'id2'
],
'loc1' => [
'id1',
'id4',
'id5',
'id9'
],
'loc3' => [
'id1',
'id11',
'id23'
]
};
答案 1 :(得分:0)
另外一个可能的选择是散列哈希。如果您想查找ID,可以说if ($locs{$loc}{$id}) {do something}
。数据结构将是
$VAR1 = {
'loc2' => {
'id2' => 1
},
'loc1' => {
'id1' => 1,
'id5' => 1,
'id4' => 1,
'id9' => 1
},
'loc3' => {
'id1' => 1,
'id11' => 1,
'id23' => 1
}
};