ThinkPHP与PHPExcel冲突解决方法
2015-01-24信息快讯网
最近一个项目需要批量导入Excel数据,要用到PHP读取Excel中的内容然后导入到数据库。
很早之前就知道有一个叫做PHPExcel的类(官方网站)可以用来操作Excel,一直没有机会尝试,今天试用发现无比强大,下载后的源码包里有详细文档,几乎能实现手工操作Excel能实现的一切功能。一个简单的读取Excel的例子如下:
$inputFileType = 'Excel2007'; $inputFileName = './public/files/import_user_template.xlsx'; $sheetname = 'Sheet1'; //指定Excel类型,创建一个reader $objReader = PHPExcel_IOFactory::createReader($inputFileType); //设置只读取数据,不包括公式和格式 $objReader->setReadDataOnly(true); //只读取指定的sheet $objReader->setLoadSheetsOnly($sheetname); $objPHPExcel = $objReader->load($inputFileName); $curSheet = $objPHPExcel->getSheet(0); //包含数据的最大列 $allColumn = $curSheet->getHighestColumn(); //包含数据的最大行 $allRow = $curSheet->getHighestRow(); for($currentRow = 1; $currentRow <= $allRow; $currentRow++){ for($currentCol = 'A'; $currentCol <= $allColumn; $currentCol++){ echo $curSheet->getCell($currentCol.$currentRow)->getValue()."\t"; } echo "\r\n"; }
要在ThinkPHP中使用,把源码包中的Classes目录复制到ThinkPHP的Vendor目录下,改名为PHPExcel,然后调用Vendor方法载入
vendor('PHPExcel.PHPExcel');
可是这样一来发现读取Excel以后再调用M或者D方法实例化模型类时报找不到Model类的错误,经过研究发现是自动装载机制冲突,要解决冲突,需要在M或者D方法调用之前使用spl_autoload_register函数重新注册autoloader类
spl_autoload_register(array('Think','autoload'));
在ThinkPHP中调用PHPExcel的问题解决方案
在ThinkPHP中调用PHPExcel时,数据可以完全读出来,但是下一步D,M或调用模板的时候会出错。(不知道是我一个人遇到这个问题 吗?)
经过研究,终于找到了解决方法。和大家分享一下。呵呵!
1,首先下载PHPExcel的包,放在 ThinkPHP/Vendor/(也就是Think的第三方类库目录)下。
2,调用函数。
protected function Import_Execl($file){ if(!file_exists($file)){ return array("error"=>1); } Vendor("PHPExcel.PHPExcel"); $PHPExcel = new PHPExcel(); $PHPReader = new PHPExcel_Reader_Excel2007(); if(!$PHPReader->canRead($file)){ $PHPReader = new PHPExcel_Reader_Excel5(); if(!$PHPReader->canRead($file)){ return array("error"=>2); } } $PHPExcel = $PHPReader->load($file); $SheetCount = $PHPExcel->getSheetCount(); for($i=0;$i<$SheetCount;$i++){ $currentSheet = $PHPExcel->getSheet($i); $allColumn = $this->ExcelChange($currentSheet->getHighestColumn()); $allRow = $currentSheet->getHighestRow(); $array[$i]["Title"] = $currentSheet->getTitle(); $array[$i]["Cols"] = $allColumn; $array[$i]["Rows"] = $allRow; $arr = array(); for($currentRow = 1 ;$currentRow<=$allRow;$currentRow++){ $row = array(); for($currentColumn=0;$currentColumn<$allColumn;$currentColumn++){ $row[$currentColumn] = $currentSheet->getCellByColumnAndRow($currentColumn,$currentRow)->getValue(); } $arr[$currentRow] = $row; } $array[$i]["Content"] = $arr; } spl_autoload_register(array('Think','autoload'));//必须的,不然ThinkPHP和PHPExcel会冲突 unset($currentSheet); unset($PHPReader); unset($PHPExcel); unlink($file); return array("error"=>0,"data"=>$array); } protected function ExcelChange($str){//配合Execl批量导入的函数 $len = strlen($str)-1; $num = 0; for($i=$len;$i>=0;$i--){ $num += (ord($str[$i]) - 64)*pow(26,$len-$i); } return $num; }
3,调用。
public function import(){ if(isset($_FILES["import"]) && ($_FILES["import"]["error"] == 0)){ $result = $this->Import_Execl($_FILES["import"]["tmp_name"]); if($this->Execl_Error[$result["error"]] == 0){ $execl_data = $result["data"][0]["Content"]; unset($execl_data[1]); $data = D("Data"); foreach($execl_data as $k=>$v){ $d["serial_no"] = $v[0]; $d["check_no"] = $v[1]; $d["work_no"] = $v[2]; $d["class_name"] = $v[3]; $d["user_name"] = $v[4]; $d["new_class"] = $v[5]; $d["error_level"] = $v[6]; $data->data($d)->add(); } $this->success($this->Execl_Error[$result["error"]]); }else{ $this->error($this->Execl_Error[$result["error"]]); } }else{ $this->error("上传文件失败"); } }
4,错误数据:
protected $Execl_Error = array("数据导入成功","找不到文件","Execl文件格式不正确");
关于shopex同步ucenter的redirect问题,导致script不运行
str_replace只替换一次字符串的方法
PHP If Else(elsefi) 语句
php中DOMElement操作xml文档实例演示
phpExcel导出大量数据出现内存溢出错误的解决方法
php字符串分割函数explode的实例代码
php中使用preg_replace函数匹配图片并加上链接的方法
php中设置index.php文件为只读的方法
php中导出数据到excel时数字变为科学计数的解决方法
php判断上传的Excel文件中是否有图片及PHPExcel库认识
PHPEXCEL 使用小记
phpexcel导出excel的颜色和网页中的颜色显示不一致
ThinkPHP 防止表单重复提交的方法
让Nginx支持ThinkPHP的URL重写和PATHINFO的方法分享
PHP源码之explode使用说明
PHP调用Webservice实例代码
PHP的explode和implode的使用说明
PHP Undefined index报错的修复方法
php max_execution_time执行时间问题
PHP 字符串正则替换函数preg_replace使用说明
php中使用explode查找某个字符是否存在的方法
PHP导出MySQL数据到Excel文件(fputcsv)
PHP函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
php编程实现获取excel文档内容的代码实例
php设计模式 Delegation(委托模式)
使用php shell命令合并图片的代码
fleaphp rolesNameField bug解决方法
PHP导入Excel到MySQL的方法
PHP生成excel时单元格内换行问题的解决方法
php excel类 phpExcel使用方法介绍