在学phpExcel的时候,在网上查了很多资料,花了很多时间,下面是我想要分享给大家的,我找到的并进行了一定修改的亲身实践成功的资料,希望大家对大家有所帮助。
首先,需要下载PhpExcel资料,下载资料可以在这里下载,http://download.csdn.net/detail/www122930/9207061
第一,将PHPExcel文件夹,和PHPExcel.php文件放在,一个新建的文件夹Excel中,将Excel文件夹放在,E:\Workspace\PHP\thinkphp2\ThinkPHP\Extend\Vendor,E:\Workspace\PHP\thinkphp2\这一部分是你创建Thinkphp的工作目录。
第二,编写一个ExcelToArray.class.php文件,将它放在E:\Workspace\PHP\thinkphp2\ThinkPHP\Extend\Library\ORG\Util,这个目录下,ExcelToArray.class.php文件的源代码如下:
<?php class ExcelToArray { public function __construct() { Vendor("Excel.PHPExcel");//引入phpexcel类(注意你自己的路径) Vendor("Excel.PHPExcel.IOFactory"); } public function read($filename,$encode,$file_type){ if(strtolower ( $file_type )=='xls')//判断excel表类型为2003还是2007 { Vendor("Excel.PHPExcel.Reader.Excel5"); $objReader = PHPExcel_IOFactory::createReader('Excel5'); }elseif(strtolower ( $file_type )=='xlsx') { Vendor("Excel.PHPExcel.Reader.Excel2007"); $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; } public function push($data,$name='Excel'){ error_reporting(E_ALL); //date_default_timezone_set('Europe/London'); $objPHPExcel = new PHPExcel(); /*以下是一些设置 ,什么作者 标题啊之类的*/ $objPHPExcel->getPRoperties()->setCreator("转弯的阳光") ->setLastModifiedBy("转弯的阳光") ->setTitle("usertable") ->setSubject("数据EXCEL导出") ->setDescription("备份数据") ->setKeyWords("excel") ->setCategory("result file"); // $objPHPExcel->setActiveSheetIndex(0) ->setCellValue('A1', 'username') ->setCellValue('B1', 'password') ->setCellValue('C1', 'sex'); /*以下就是对处理Excel里的数据, 横着取数据,主要是这一步,其他基本都不要改*/ for ($i = 0; $i < count($data) - 1; $i++) { $objPHPExcel->getActiveSheet(0)->setCellValue('A' . ($i + 2), $data[$i]['username']); $objPHPExcel->getActiveSheet(0)->setCellValue('B' . ($i + 2), $data[$i]['password']); $objPHPExcel->getActiveSheet(0)->setCellValue('C' . ($i + 2), $data[$i]['sex']); } $objPHPExcel->getActiveSheet()->setTitle('User'); $objPHPExcel->setActiveSheetIndex(0); ob_end_clean(); //清除缓冲区,避免乱码 header('Content-Type: application/vnd.ms-excel'); header('Content-Disposition: attachment;filename="'.$name.'.xls"'); header('Cache-Control: max-age=0'); $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); $objWriter->save('php://output'); exit; } }
这里有两部分,一部分read function,就是读入Excel中,即将数据库中内容导入到Excel,另一部分,push function,就是讲Excel数据上传到数据库。
第三,创建一个ExcelAction.clsaa.php,在目录E:\Workspace\PHP\thinkphp2\Home\Lib\Action下面,ExcelAction.clsaa.php源代码如下:
1 <?php 2 class ExcelAction extends Action { 3 public function __construct() 4 { 5 import('ORG.Util.ExcelToArray');//导入excelToArray类 6 } 7 8 public function index() 9 { 10 $this->display(); 11 } 12 public function add() 13 { 14 dump($_FILES); 15 16 $tmp_file = $_FILES ['file_stu'] ['tmp_name']; 17 $file_types = explode ( ".", $_FILES ['file_stu'] ['name'] ); 18 $file_type = $file_types [count ( $file_types ) - 1]; 19 20 /*判别是不是.xls文件,判别是不是excel文件*/ 21 if (strtolower ( $file_type ) != "xlsx" && strtolower ( $file_type ) != "xls") 22 { 23 $this->error ( '不是Excel文件,重新上传' ); 24 } 25 26 /*设置上传路径*/ 27 $savePath = 'E:\Workspace\PHP\thinkphp\Uploads\\'; 28 /*以时间来命名上传的文件*/ 29 $str = date ( 'Ymdhis' ); 30 $file_name = $str . "." . $file_type; 31 32 /*是否上传成功*/ 33 if (! copy ( $tmp_file, $savePath . $file_name )) 34 { 35 $this->error ( '上传失败' ); 36 } 37 $ExcelToArray=new ExcelToArray();//实例化 38 $res=$ExcelToArray->read($savePath.$file_name,"UTF-8",$file_type);//传参,判断office2007还是office2003 39 foreach ( $res as $k => $v ) //循环excel表 40 {
//这一步判断,是为了在Excel内第一行一定是行标题,这里将第一行忽略,直接从第二行读入数据,若没有行标题,则不需要进行if判断,且$k=$k-1; 41 if($k!=1){ 42 $k=$k-2;//addAll方法要求数组必须有0索引 43 $data[$k]['username'] = $v[0];//创建二维数组 44 $data[$k]['password'] = $v[1]; 45 $data[$k]['sex'] = $v [2]; 46 } 47 } 48 49 //dump($data[0]); 50 $kucun=M('User');//M方法 51 $result=$kucun->addAll($data); 52 if(! $result) 53 { 54 $this->error('导入数据库失败'); 55 exit(); 56 } 57 else 58 { 59 $this->success ( '导入成功' ); 60 } 61 } 62 63 public function load(){ 64 $data= M('User')->select(); //查出数据 65 dump($data); 66 $name='Usertable'; //生成的Excel文件文件名 67 $ExcelToArray=new ExcelToArray();//实例化 68 $res=$ExcelToArray->push($data,$name); 69 } 70 }
第四,就是创建相应的模板,在目录E:\Workspace\PHP\thinkphp2\Home\Tpl下,创建Excel文件夹,新建index.html文件,源代码如下:
1 <form method="post" action="__APP__/Excel/add" enctype="multipart/form-data"> 2 <h3>导入Excel表:</h3><input type="file" name="file_stu" /> 3 4 <input type="submit" value="导入" /> 5 </form> 6 <form method="post" action="__APP__/Excel/load" enctype="multipart/form-data"> 7 <input type="submit" value="导出" /> 8 </form>
最后,只需要进行测试就可以了。
ps,数据库信息如下:
例如:新建数据库thinkphp,建立表user,user表信息如下:
id | username | password | sex |
1 | zs | 123 | 1 |
以上就是使用PhpExcel的全部步骤,谢谢!