免费注册 查看新帖 |

Chinaunix

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

perl操作excel新手求助 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-02-04 10:50 |只看该作者 |倒序浏览
本人刚学习perl没几天,现在需求是 同时从excel表1和表2中 各提取一行或一列数据写入表3中,表3可以是新建的也可以是现有的。不知该怎么做,我零零散散看了些方法,试过用模块ParseExcel和WirteExcel ,可是从表1提取的数据始终把表2的覆盖了,也就是表3里始终只能有一张表的数据,求解这代码该怎么写呢

求职 : Linux运维
论坛徽章:
3
戌狗
日期:2015-01-11 13:27:532015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯纪念徽章
日期:2015-05-08 15:03:30
2 [报告]
发表于 2015-02-04 11:44 |只看该作者
以前写的代码供参考
  1. #!/usr/bin/perl -w
  2. use strict;
  3. use Encode;
  4. use Spreadsheet::WriteExcel;
  5. use Spreadsheet::ParseExcel;

  6. my $file='D:\1.xls';
  7. $file = encode('gb2312',decode('utf-8',$file));
  8. my $parser = Spreadsheet::ParseExcel->new();
  9. my $book =$parser->parse($file);
  10. my @sheets = $book->worksheets();
  11. foreach my $sheet (@sheets){
  12.         my $sheetname = $sheet->get_name();
  13.         $sheetname = encode('gb2312',$sheetname);
  14.         print "\n***************$sheetname***************\n";

  15.         my ($minRow, $maxRow) = $sheet->row_range();
  16.         my ($minCol, $maxCol) = $sheet->col_range();

  17.         foreach my $row ($minRow..$maxRow){
  18.                 print "====Row $row====\n";
  19.                 foreach my $col ($minCol..$maxCol){
  20.                     my $cell = $sheet->get_cell($row, $col);
  21.                         next unless defined($cell);
  22.                         my $value = encode('gb2312',$cell->value);
  23.                         print "($value) ";
  24.                 }
  25.                 print "\n";
  26.         }
复制代码

论坛徽章:
1
狮子座
日期:2014-02-25 09:46:33
3 [报告]
发表于 2015-02-09 21:23 |只看该作者
表1 或表2 或表3可不可以贴上点例子,这样凭空想你要做的事有点费劲啊

论坛徽章:
0
4 [报告]
发表于 2015-02-11 00:00 |只看该作者
第一个表的数据写完了 把行和列存着 下一个表写的时候在存的行和列的基础上再写,估计你都是直接往同样的行和列里面写了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP