ThinkPHP使用PHPExcel出现:Class 'Admin\Action\PHPExcel_IOFactory' not found

今天,使用TP的PHPExcel在做excel的导入和导出,出现个错误:

Class 'Admin\Action\PHPExcel_IOFactory' not found

我使用的是:

	import("Org.Util.PHPExcel");
	import("Org.Util.PHPExcel.Writer.Excel5");
	import("Org.Util.PHPExcel.IOFactory.php");
	$objReader = PHPExcel_IOFactory::createReader('Excel5');
查看了下,import代码

var_dump(class_exists('PHPExcel_IOFactory'));// 返回的是true...

好奇怪,这个问题。查看import源码,在最后的引入类文件,进行了输出,如下:

/private/var/www/backend/ThinkPHP/Library/Org/Util/PHPExcel.class.php
/private/var/www/backend/ThinkPHP/Library/Org/Util/PHPExcel/Writer/Excel5.class.php
/private/var/www/backend/ThinkPHP/Library/Org/Util/PHPExcel/IOFactory/php.class.php

查看了是因为 'import()' 的问题,import()默认会给文件添加 '.class.php'的后缀。同时将 '.' 替换为 '/',导致文件路径也解析错误。


解决方案:

网上的调用方式不对,正确的方式:

	import("Org.Util.PHPExcel");
	import("Org.Util.PHPExcel.Writer.Excel5", '', '.php');
	import("Org.Util.PHPExcel.IOFactory", '', '.php');

这次引入的文件应该没问题了

可能同版本有关,这个版本是3.2.3

还有一个特别注意事项:

$objReader = \PHPExcel_IOFactory::createReader('Excel5');

必须以 '\' 开头,命名空间之类的!


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值