6
 foreach my $row (1..$end) 
 { 
  foreach my $col (3..27 ) 
  { 
    # skip empty cells 
    next unless defined 
    $worksheet->Cells($row,$col)->{'Value'}; 

    # print out the contents of a cell  
    $var = $worksheet->Cells($row,$col)->{'Value'};     
    push @dates, $var;  

    print $var; #this prints the value just fine
  } 
 }  

my %hash;
$hash{'first'} = \@dates;
print Dumper \%hash; #This prints object information 

我正在使用用于 Perl 的模块 OLE 以及从工作表中获得的每个值并打印 $var 然后我得到预期值,但是当我将所有内容放入哈希中时,它会打印:

'first' => [
bless( do{\(my $o = 15375916)}, 'OLE::Variant'), 
bless( do{\(my $o = 15372208)}, 'OLE::Variant'),

等等。我一定不了解哈希,因为我真的很难过。

4

2 回答 2

10

push @dates, $var将一个OLE::Variant对象推送到您的@dates数组上,同时print $var调用隐式OLE::Variant方法将对象转换为字符串。

如果您还想@dates只包含基础字符串值而不是对象本身,请说

push @dates, "$var";

这将在将日期对象放入@dates数组之前对其进行字符串化。

于 2011-02-01T17:45:38.897 回答
4

调用返回的值$worksheet->Cells($row,$col)->{'Value'}是本质上主要是 C/C++ 的对象,而 Perl 只有一个对象句柄,由一个内存位置表示(您在转储中看到的是一个大整数)。许多包装底层 C/C++ 库的 CPAN 模块的行为方式相同(XML::LibXML 就是一个例子)。简短的回答是,这就是对象,不幸的是,您可以通过 Data::Dumper 看到它。它们本质上是有福的标量引用,对它们的所有操作都是通过方法,而不是通过底层引用本身的实际值。

于 2011-02-01T21:29:50.223 回答