免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2740 | 回复: 3
打印 上一主题 下一主题

Spreadsheet::ParseExcel不能处理加载宏的excel文件吗? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-12-03 17:48 |只看该作者 |倒序浏览
不加载宏的可以打印,加载的就打印不出来,究竟怎样才能处理加载宏的excel文件?


  1. use strict;
  2. use Spreadsheet::ParseExcel;
  3. use Encode;
  4. die "You must provide a filename to $0 to be parsed as an Excel file" unless @ARGV==1;
  5. my $file=shift;
  6. my %count;
  7. my $excel = Spreadsheet::ParseExcel::Workbook->Parse($file);
  8. foreach my $sheet (@{$excel->{Worksheet}}[0..2]) {
  9. printf("Sheet: %s\n", $sheet->{Name});
  10. foreach my $row ($sheet->{MinRow} .. $sheet->{MaxRow}) {
  11.    my $cell = $sheet->{Cells}[$row][1];
  12.    if ($cell) {
  13.     $count{decode('GB2312',$cell->{Val})}++;
  14.     #printf("( %s , %s ) => %s\n", $row, 5, $cell->{Val});
  15.    }
  16. }
  17. }
  18. for my $c(sort keys %count)
  19. { print "$c,$count{$c}\n"; print "haha\n";}
复制代码

论坛徽章:
1
未羊
日期:2014-09-08 22:47:27
2 [报告]
发表于 2008-12-03 19:50 |只看该作者
如果是Windows环境,建议用Win32::OLE模块。

论坛徽章:
0
3 [报告]
发表于 2008-12-08 09:21 |只看该作者
Win32::OLE模块如何读取excel工作表内容,有没有相关例子?我暂时找不到

论坛徽章:
1
未羊
日期:2014-09-08 22:47:27
4 [报告]
发表于 2008-12-08 15:50 |只看该作者
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP