免费注册 查看新帖 |

Chinaunix

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

求助win32::OLE中excel中文问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-04-13 11:34 |只看该作者 |倒序浏览
我要从excel中取数据,用正则寻找特定行,方法为$temp=~/Li含量/,匹配/Li/则没问题,说明是中文引起的,因此用以下代码调查原因。
  1. if(defined($_[0]->Cells($x,'B')->{Value})){
  2.                         $temp = $_[0]->Cells($x,'B')->{Value};
  3.                         print $temp," length is:",length($temp),"\n";
  4.                                 $temp = decode("gb2312",$temp);
  5.                                 print $temp,"length is:",length $temp,"\n";
  6.                                 my @tempa = split //,$temp;
  7.                                 print join("\t",@tempa),"\n";
  8.                                 foreach (@tempa){$_=encode("cp936",$_);}
  9.                         $temp = join ("",@tempa);
  10.                         print @tempa,"scalar is:",scalar(@tempa),"\n";
  11.                         print $temp," length is:", length($temp),"\n";
  12. }
复制代码
结果如下:
---
锂盐 length is:4
Wide character in print at test.pl line 36.
閿傜洂length is:2
Wide character in print at test.pl line 38.
閿?鐩?
锂盐scalar is:2
锂盐 length is:4
----
不能理解的是,为何split后为两个元素,为何join后长度又变成了4,最终仍然无法正确匹配中文。excel到底是什么编码,如何才能正确进行中文匹配呢?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP