如何将可变长度的行分配给perl中的变量?

时间:2014-01-30 23:23:19

标签: perl hash

我有一个我想要阅读的文件,每个位置都有可变数量的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的新手,仍然试图了解不同的数据类型。

有什么想法吗?非常感谢!

2 个答案:

答案 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
                    }
        };