欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

关于PHPExcel,phpexcel

程序员文章站 2022-04-18 16:44:12
...

关于PHPExcel,phpexcel

  在学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文件的源代码如下:

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 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 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 
2

导入Excel表:

3 4 5
6
7 8

  最后,只需要进行测试就可以了。

  ps,数据库信息如下:

  例如:新建数据库thinkphp,建立表user,user表信息如下:

id username password sex
1 zs 123 1

  以上就是使用PhpExcel的全部步骤,谢谢!