⑴ Thinkphp引入第三方类库PHPExcel后,总是提示找不到模块
提示信息:就是找不到控制器,可能你的路径不正确;
vendor文件夹下-》PHPExcel-》PHPExcel-》再加上你要引入的第三方类库里面的文件名
3.修改方法: 试一下
vendor("PHPExcel.PHPExcel.index");
⑵ thinkphp3.1中的phpexcel导入怎么用
首先,去PHPExcel官方网站下载PHPExcel,官方地址为;http://phpexcel.codeplex.com/.我下的是1.8.0版本的.解压后发现还是蛮大的,有十几M,不知道其他版本是不是会小点.
这里写图片描述
把解压好的PHPExcel文件放在ThinkPHP的Vender文件夹下(专门放第三方类库的),如下图
这里写图片描述
其次,创建Excel转换数组类,并把它放在ThinkPHP\Extend\Library\ORG\Util目录下
class ExcelToArrary {
public function __construct() {
Vendor("PHPExcel.Classes.PHPExcel");//引入phpexcel类(留意路径,不了解路径可以查看下手册)
Vendor("PHPExcel.Classes.PHPExcel.IOFactory"); //引入phpexcel类(留意路径)
}
public function read($filename,$encode,$file_type){
if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel5"); //引入phpexcel类(留意路径)
$objReader = PHPExcel_IOFactory::createReader('Excel5');
}elseif(strtolower ( $file_type )=='xlsx')
{
Vendor("PHPExcel.Classes.PHPExcel.Reader.Excel2007");//引入phpexcel类(留意路径)
$objReader = PHPExcel_IOFactory::createReader('Excel2007');
}
$objReader->setReadDataOnly(true);
$objPHPExcel = $objReader->load($filename);
$objWorksheet = $objPHPExcel->getActiveSheet();
$highestRow = $objWorksheet->getHighestRow();
$highestColumn = $objWorksheet->getHighestColumn();
$highestColumnIndex = PHPExcel_Cell::columnIndexFromString($highestColumn);
$excelData = array();
for ($row = 1; $row <= $highestRow; $row++) {
for ($col = 0; $col < $highestColumnIndex; $col++) {
$excelData[$row][] =(string)$objWorksheet->getCellByColumnAndRow($col, $row)->getValue();
}
}
return $excelData;
}
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
如右图这里写图片描述
现在来说Excel,表格的结构样式和MySQL样式要类似,表格样式如下(本人对Excel使用只是一般,所以如果有Excel大神做的报表,不知后果如何).
这里写图片描述
前端页面相关代码:
<div>
<form method="post" action="{:U('Index/upload')}" enctype="multipart/form-data">
<font>导入Excel数据:</font>
<label for="file_stu">上传</label>
<input name="file_stu" type="file" id="file_stu" />
<h3>温馨提示:</h3>
<p>请确认您的Excel表格类型是xls的,以免出现兼容问题.</p>
<inputtypeinputtype="submit" class="sure" value="导入" />
</form>
</div>
1
2
3
4
5
6
7
8
9
10
1
2
3
4
5
6
7
8
9
10
最后,控制器部分使用了Thinkphp自带的上传类,使用unlink()函数是为了删除上传的excel表格,以免文件夹存入过多文件,调试代码时可先注释掉.或者不写也行,把删除文件的工作交给你们的运维.代码中foreach循环部分$v[]里的0, 1,2可以改动以下看看与Excel表格里的内容是什么关系.可以把数组打印出来看一看,你就很清楚了
相关代码:
public function upload(){
import('ORG.Util.ExcelToArrary');//导入excelToArray类
if (! empty ( $_FILES ['file_stu'] ['name'] )){
import('ORG.Net.UploadFile');
$upload = new UploadFile();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小
$upload->allowExts = array('xls', 'xlsx');// 设置附件上传类型
$upload->savePath = './Uploads/';// 设置附件上传目录
if(!$upload->upload()) {// 上传错误提示错误信息
$this->error($upload->getErrorMsg());
}else{// 上传成功 获取上传文件信息
$info = $upload->getUploadFileInfo();
}
}else{
$this->error('(⊙o⊙)~没传数据就导入?!你在逗我?!');
}
//mp($info);die;
$ExcelToArrary=new ExcelToArrary();//实例化
$res=$ExcelToArrary->read($info[0]['savepath'].$info[0]['savename'],"UTF-8",$info[0]['extension']);//传参,判断office2007还是office2003
$res = array_slice($res,1); //为了去掉Excel里的表头,也就是$res数组里的$res[0];
//mp($res);
foreach ( $res as $k => $v ){ //循环excel表
$data[$k]['mobile'] = $v [0];//创建二维数组
$data[$k]['name'] = $v [1];
$data[$k]['ty'] = $v [2];
}
//mp($data);die;
$result=M('appkey')->addAll($data);
if(!$result){
$this->error('导入数据库失败');
exit();
}else{
$filename = './Uploads/'.$info[0]['savename'];//上传文件绝对路径,unlink()删除文件函数
if (unlink($filename)) {
$this->success ( '导入成功' );
}else{
$this->error('缓存删除失败');
}
}
}
⑶ PHP 用PHPExcel往数据库导入大量数据
1、首先我们准备一个含有数据的Excel表格,表头和数据表中的表字段相对应。
⑷ php怎么读取excel 文件数据并输出
PHPExcel是用来操作Office Excel 文档的一个PHP类库,它基于微软的OpenXML标准和PHP语言。可以使用它来读取、写入不同格式的电子表格,如 Excel (BIFF) .xls, Excel 2007 (OfficeOpenXML) .xlsx, CSV, Libre/OpenOffice Calc .ods, Gnumeric, PDF, HTML等等。
PHP读取示例代码
//获取上传的excel临时文件
$path=$_FILES["file"]["tmp_name"];
//将临时文件移动当前目录,可自定义存储位置
move_uploaded_file($_FILES["file"]["tmp_name"],$_FILES["file"]["name"]);
//将获取在服务器中的Excel文件,此处为上传文件名
$path=$_FILES["file"]["name"];
//调用readExcel函数返回一个
二维数组
$exceArray=readExcel($path);
//创建一个读取
excel函数
functionreadExcel($path){
//引入PHPExcel类库
include'Classes/PHPExcel.php';
include'Classes/PHPExcel/IOFactory.php';
$type='Excel5';//设置为Excel5代表支持2003或以下版本,
Excel2007代表2007版
$xlsReader=PHPExcel_IOFactory::createReader($type);
$xlsReader->setReadDataOnly(true);
$xlsReader->setLoadSheetsOnly(true);
$Sheets=$xlsReader->load($path);
//开始读取上传到服务器中的Excel文件,返回一个
二维数组
$dataArray=$Sheets->getSheet(0)->
toArray();
return$dataArray;
}
⑸ 如何加载第三方类库phpexcel的所有PHP文件
第一步 网上下载PHPExcel类库包,解压后
打开Classes目录可以看到有个PHPExcel.php文件,将这个文件更名为PHPExcel.class.php
第二步 将整个目录放到项目的ORG目录下此时的目录结构
第三步利用thinkphp的import方法在Action中将PHPExcel类导入
import ( '@.ORG.PHPExcel.Classes.PHPExcel' );
这样你就可以使用PHPExcel类库所提供的操作Excel文档的方法了
⑹ 怎么用phpexcel怎么导出excel文件
下载phpexcel类库 代码如下:x0dx0aarray('id'=>2013,'name'=>'张某某','age'=>21),x0dx0a 1=>array('id'=>201,'name'=>'EVA','age'=>21)x0dx0a );x0dx0a //设置excel列名x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1','编号');x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('B1','姓名');x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('C1','年龄');x0dx0a //把数据循环写入excel中x0dx0a foreach($data as $key => $value){x0dx0a $key+=2;x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A'.$key,$value['id']);x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('B'.$key,$value['name']);x0dx0a $objPHPExcel->setActiveSheetIndex(0)->setCellValue('C'.$key,$value['age']);x0dx0a }x0dx0a //excel保存在根目录下 如要导出文件,以下改为注释代码x0dx0a $objPHPExcel->getActiveSheet() -> setTitle('SetExcelName');x0dx0a $objPHPExcel-> setActiveSheetIndex(0);x0dx0a $objWriter = $iofactory -> createWriter($objPHPExcel, 'Excel2007');x0dx0a $objWriter -> save('SetExcelName.xlsx');x0dx0a //导出代码x0dx0a // $objPHPExcel->getActiveSheet() -> setTitle('SetExcelName');x0dx0a // $objPHPExcel-> setActiveSheetIndex(0);x0dx0a // $objWriter = $iofactory -> createWriter($objPHPExcel, 'Excel2007');x0dx0a // $filename = 'SetExcelName.xlsx'x0dx0a // header('Content-Type: application/vnd.ms-excel');x0dx0a // header('Content-Type: application/octet-stream');x0dx0a // header('Content-Disposition: attachment; filename="' . $filename . '"');x0dx0a // header('Cache-Control: max-age=0');x0dx0a // $objWriter -> save('php://output');x0dx0a?>