亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費(fèi)注冊(cè) 查看新帖 |

Chinaunix

  平臺(tái) 論壇 博客 文庫
最近訪問板塊 發(fā)新帖
查看: 2539 | 回復(fù): 9
打印 上一主題 下一主題

求高手幫忙,perl處理excel中文 [復(fù)制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報(bào)告]
發(fā)表于 2013-04-28 14:53 |只看該作者 |倒序?yàn)g覽
本帖最后由 wangjj20 于 2013-04-28 14:57 編輯

perl菜鳥求助。

現(xiàn)在用perl處理excel的文件,提取出指定的行列的數(shù)據(jù),摸索了下功能實(shí)現(xiàn)了,但是如果指定的數(shù)據(jù)是中文,print出來的就不對(duì)。不知道如何處理,在線求助。

代碼如下:
  1. #!/usr/bin/perl
  2. use Spreadsheet::Read;
  3. use Data::Dumper;
  4. use Spreadsheet::ParseExcel;
  5. use Spreadsheet::WriteExcel;
  6. use Encode qw(decode);

  7. my $soruce_dir      = './excel';

  8. my $parser   = Spreadsheet::ParseExcel->new();
  9. my $workbook = $parser->Parse("$soruce_dir/test.xls");

  10. for my $worksheet ( $workbook->worksheets() ) {
  11.     my $row=2;
  12.     my $col1=2;
  13.     my $cell = $worksheet->get_cell( $row, $col1 );
  14.        next unless $cell;

  15. my $stid= $cell->unformatted(), "\n";

  16. print "$stid\n";

  17. [color=Red]my $xh=&T($stid);

  18. print "$xh\n";
  19.         };

  20. sub T {
  21.     my $text = shift;
  22.     return decode( 'GB2312', $text );
  23. }[/color]
復(fù)制代碼
試過了GB2312,UTF8,但是中文還是不能正常顯示。


另外excel表格內(nèi)容如下:

論壇徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-12-01 06:20:002015亞冠之首爾
日期:2015-11-04 22:25:43IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27獅子座
日期:2014-05-12 11:00:00辰龍
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年紀(jì)念徽章
日期:2013-10-24 15:41:34IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-27 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2016-06-07 14:10:01
2 [報(bào)告]
發(fā)表于 2013-04-28 15:09 |只看該作者
本帖最后由 laputa73 于 2013-04-28 15:14 編輯

沒設(shè)format
$Format= $dest_book->add_format();
$Format->set_font(decode("gb2312",'微軟雅黑'));
$dest_sheet->write($LineNum,6,decode("gb2312", 'xxxxx' ),$Format);

論壇徽章:
0
3 [報(bào)告]
發(fā)表于 2013-04-28 15:09 |只看該作者
http://www.72891.cn/forum.php?mod=viewthread&tid=1626493

版主的終結(jié)者貼,肯定能終結(jié)你的問題!

論壇徽章:
0
4 [報(bào)告]
發(fā)表于 2013-04-28 15:34 |只看該作者
回復(fù) 3# iamlimeng


   高手,沒看懂啊。

my $fmt = new MyExcelFormatter(); 這一行之外。
這一行生成了一個(gè)文檔內(nèi)容的轉(zhuǎn)換器(格式化工具),
轉(zhuǎn)換器代碼如下:

這一段不明真相,這段代碼寫在哪的?

論壇徽章:
0
5 [報(bào)告]
發(fā)表于 2013-04-28 15:36 |只看該作者
本帖最后由 wangjj20 于 2013-04-28 15:36 編輯

回復(fù) 2# laputa73


    我現(xiàn)在就是想取到c3這個(gè)格的值,然后print出來是正常顯示的。。不用寫入新的excel中。

論壇徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-12-01 06:20:002015亞冠之首爾
日期:2015-11-04 22:25:43IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27獅子座
日期:2014-05-12 11:00:00辰龍
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年紀(jì)念徽章
日期:2013-10-24 15:41:34IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-27 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2016-06-07 14:10:01
6 [報(bào)告]
發(fā)表于 2013-04-28 15:55 |只看該作者
讀和寫類似
my $xls = Spreadsheet:arseExcel::Workbook->arse( $file, $fmt );
就是這里要指定$fmt啊
版主那個(gè)文章里面有源碼了阿

論壇徽章:
0
7 [報(bào)告]
發(fā)表于 2013-04-28 16:03 |只看該作者
回復(fù) 6# laputa73




my $fmt = new MyExcelFormatter(); 這一行之外。
這一行生成了一個(gè)文檔內(nèi)容的轉(zhuǎn)換器(格式化工具),
轉(zhuǎn)換器代碼如下:

這一段不明真相,這段代碼寫在哪的?請(qǐng)指點(diǎn)。

論壇徽章:
0
8 [報(bào)告]
發(fā)表于 2013-04-28 16:43 |只看該作者
本帖最后由 iamlimeng 于 2013-04-28 16:43 編輯

在程序中引用:
  1. use MyExcelFormatter;
  2. my $fmt = new MyExcelFormatter();
復(fù)制代碼
轉(zhuǎn)換器如下:
MyExcelFormatter.pm
  1. package MyExcelFormatter;

  2. use strict;
  3. use warnings;

  4. use base qw(Spreadsheet::ParseExcel::FmtDefault);

  5. use Encode::CN;
  6. use Encode qw(from_to);

  7. sub new() {
  8.     return bless {};
  9. }

  10. sub TextFmt( $;$ ) {
  11.     my $this = shift;
  12.     my ($value, $code) = @_;

  13.     if ( defined $code and $code eq 'ucs2' ){
  14.         from_to( $value, 'ucs2', 'gb2312' );
  15.     }
  16.     return $value;
  17. }

  18. 1;
復(fù)制代碼

論壇徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30數(shù)據(jù)庫技術(shù)版塊每日發(fā)帖之星
日期:2015-12-01 06:20:002015亞冠之首爾
日期:2015-11-04 22:25:43IT運(yùn)維版塊每日發(fā)帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27獅子座
日期:2014-05-12 11:00:00辰龍
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年紀(jì)念徽章
日期:2013-10-24 15:41:34IT運(yùn)維版塊每日發(fā)帖之星
日期:2016-01-27 06:20:0015-16賽季CBA聯(lián)賽之新疆
日期:2016-06-07 14:10:01
9 [報(bào)告]
發(fā)表于 2013-04-28 18:06 |只看該作者
要自己寫個(gè)pm文件MyExcelFormatter.pm
,放在perl能找到的地方

論壇徽章:
0
10 [報(bào)告]
發(fā)表于 2013-04-28 19:49 |只看該作者
我把  
my $cell = $worksheet->get_cell( $row, $col1 );
next unless $cell;
這樣取出來的值放入數(shù)組,再?gòu)臄?shù)組里面提取就能正常顯示了。。

push @p1, $cell->value();
my $stid    = $p1[0];
print "$stid\n";
您需要登錄后才可以回帖 登錄 | 注冊(cè)

本版積分規(guī)則 發(fā)表回復(fù)

  

北京盛拓優(yōu)訊信息技術(shù)有限公司. 版權(quán)所有 京ICP備16024965號(hào)-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號(hào):11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報(bào)專區(qū)
中國(guó)互聯(lián)網(wǎng)協(xié)會(huì)會(huì)員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關(guān)心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請(qǐng)注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP