+ -
当前位置:首页 → 问答吧 → 怎么读取excel里面的数据?

怎么读取excel里面的数据?

时间:2010-12-23

来源:互联网

我想要读取excel里面第一排里面所有的数据,应该怎么写?

作者: james_zhenghao   发布时间: 2010-12-23

右上角搜索,本版很多

作者: zhlong8   发布时间: 2010-12-23

用  Spreadsheet:arseExcel 这个模块可以处理的

作者: scrit   发布时间: 2010-12-23

本帖最后由 yiten 于 2010-12-23 15:30 编辑

我这边有现成的,做下好人
  1. # parse excel 2003 file and return the data
  2. # examples:
  3. # 1. read the first sheet data: read_excel_2003('abc.xls'), return reference of sheet data
  4. # 2. read all the sheet data: read_excel_2003( 'abc.xls', 1 ), return array reference contains reference of every sheet data
  5. # 3. read specified sheet data: read_excel_2003( 'abc.xls', [ 0, 1, 4 ] ), return hash reference contains reference of the specified sheet data
  6. sub read_excel_2003 {
  7.     my ( $file, $sheet_var ) = @_;

  8.     die "File is not found: $file." unless -e $file;

  9.     my $parser = Spreadsheet::ParseExcel->new();
  10.     my $fmt = Spreadsheet::ParseExcel::FmtUnicode->new( Unicode_Map => 'CP936' );

  11.     my $workbook = $parser->Parse( $file, $fmt );

  12.     die $parser->error() unless $workbook;

  13.     unless ( $sheet_var ) {
  14.         return _parse_sheet( $workbook->worksheet(0) );
  15.     }
  16.     elsif ( !ref $sheet_var ) {
  17.         my @result_array = ();

  18.         for my $worksheet ( $workbook->worksheets() ) {
  19.             push @result_array, _parse_sheet($worksheet);
  20.         }

  21.         return \@result_array;
  22.     }
  23.     elsif ( ref $sheet_var eq 'ARRAY' ) {
  24.         my %result_hash = ();
  25.         
  26.         for my $sheet_num ( @$sheet_var ) {
  27.             my $worksheet = $workbook->worksheet($sheet_num);
  28.             $result_hash{$sheet_num} = _parse_sheet($worksheet) if $worksheet;
  29.         }

  30.         return \%result_hash;
  31.     }
  32. }

  33. sub _parse_sheet {
  34.     my $worksheet = shift;

  35.     my @sheet_array = ();

  36.     my ( $row_min, $row_max ) = $worksheet->row_range();
  37.     my ( $col_min, $col_max ) = $worksheet->col_range();

  38.     for my $row ( $row_min .. $row_max ) {
  39.         my @row_array = ();

  40.         for my $col ( $col_min .. $col_max ) {
  41.             my $cell = $worksheet->get_cell( $row, $col );

  42.             if ($cell) {
  43.                 if ( $cell->type() eq 'Date' ) {
  44.                     push @row_array, ExcelFmt( 'yyyy-mm-dd HH:MM:SS', $cell->unformatted() );
  45.                 }
  46.                 else {
  47.                     push @row_array, $cell->value();
  48.                 }
  49.             }
  50.             else {
  51.                 push @row_array, undef;
  52.             }
  53.         }

  54.         push @sheet_array, \@row_array;
  55.     }

  56.     return \@sheet_array;
  57. }
复制代码

作者: yiten   发布时间: 2010-12-23