Perl讀取Excel檔案並解決中文亂碼問題

來源:互聯網
上載者:User

標籤:excel   中文亂碼   perl   

使用CPAN中的Spreadsheet::ParseExcel模組讀取Excel檔案中的內容,當遇到中文亂碼問題時,使用Spreadsheet::ParseExcel::FmtUnicode模組重新編碼,當將中文賦值給變數時,用Encode模組經GB2312解碼即可。

use strict;  use Spreadsheet::ParseExcel;  use Spreadsheet::ParseExcel::FmtUnicode;use Encode;     my $oFmtC=Spreadsheet::ParseExcel::FmtUnicode->new(Unicode_Map=>"CP936");  my $parser=Spreadsheet::ParseExcel->new();  my $workbook=$parser->parse(‘test.xls‘,$oFmtC);     if (!defined $workbook){      die $parser->error(),".\n";  }     for my $worksheet ($workbook->worksheets()){      my ($row_min,$row_max)=$worksheet->row_range();      my ($col_min,$col_max)=$worksheet->col_range();      for (my $row=$row_min;$row<=$row_max;$row++){         for (my $col=$col_min;$col<=$col_max;$col++){              my $cell = $worksheet->get_cell($row,$col);             $a=$cell->value();              $a=decode("gb2312",$a);            #do something         }      }  }


本文出自 “如意靈臨” 部落格,請務必保留此出處http://417722381.blog.51cto.com/7856838/1880722

Perl讀取Excel檔案並解決中文亂碼問題

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.