当前位置: 移动技术网 > IT编程>开发语言>PHP > ThinkPHP与PHPExcel冲突解决方法

ThinkPHP与PHPExcel冲突解决方法

2019年04月21日  | 移动技术网IT编程  | 我要评论
很早之前就知道有一个叫做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文件格式不正确");

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网