in reply to Accessing values in a XSL file.
The problem is that using a cell handler calls your cell handler as each cell is read. You don't really need to do that under normal circumstances, but if you do, then try something like:
#!/usr/bin/perl -w use strict; use warnings; use Spreadsheet::ParseExcel; my %CellData; # Key1=workbook, Key2=Row, Key3=column my $parse_excel = Spreadsheet::ParseExcel->new( CellHandler => \&cell_handler, NotSetCell => 1 ); my $workbook = $parse_excel->Parse('file.xls'); # Now that we've parsed the sheet, we can access any data we like, # So let's print cell C1 on sheet "FOO" print $CellData{FOO}{C}{1}, "\n"; sub cell_handler { # Cell information passed to us my ($WB, $IDX, $R, $C, $Cell) = @_; # Build our hash keys my $SheetName = $WB->worksheet($IDX)->get_name(); my $ColName = numToColumnName($C); my $RowName = $R; $CellData{$SheetName}{$ColName}{$RowName} = $Cell->{_Value}; } sub numToColumnName { my $C = shift; my $colName = ''; if ($C>25) { $colName = substr('ABCDEFGHIJKLMNOPQRSTUVWXYZ', $C/26, 1); $C = $C % 26; } $colName .= substr('ABCDEFGHIJKLMNOPQRSTUVWXYZ', $C, 1); }
(Note: Untested!)
Of course, if you don't need to use a cell handler, you can just use the example in the first page of the documentation to access the data by sheet / row / column...
...roboticus
|
|---|
| Replies are listed 'Best First'. | |
|---|---|
|
Re^2: Accessing values in a XSL file.
by Anonymous Monk on Oct 27, 2010 at 17:19 UTC | |
by jmcnamara (Monsignor) on Oct 27, 2010 at 17:33 UTC | |
by Anonymous Monk on Oct 27, 2010 at 17:46 UTC | |
by jmcnamara (Monsignor) on Oct 27, 2010 at 17:51 UTC | |
by Anonymous Monk on Oct 27, 2010 at 18:05 UTC | |
|