PHPExcel从数据库表导出到Excel表

时间:2021-08-09 01:31:32

                                      关于用PHPExcel从数据库表导出到Excel表

     在网上查了好多关于这方面的资料,今天终于把这个问题解决了。

     我个人感觉 PHPExcel还是很好用的,首先到官方网站http://phpexcel.codeplex.com/下载最近版本的PHPExcel,解压后会发现里面有class、Documentation、Tests三个文件夹和三个txt的日志文件,主要用到的是Class文件,而Tests主要是一些demo示例

     下面来介绍一下PHPExcel的简单用法,这里是与数据库连接的:

      首先,要包含PHPExcel.php

       require_once 'Classes/PHPExcel.php';          //路径根据自己实际项目的路径进行设置
       $objPHPExcel = new PHPExcel();  //创建PHPExcel实例

   //下面是对mysql数据库的连接   

$conn = mysql_connect("localhost","root","") or die("数据库连接失败!");   

 mysql_select_db("image",$conn);               //连接数据库

 mysql_query("set names 'GBK'");               //转换字符编码
 $sql = mysql_query("select * from test");    //查询sql语句

/*--------------设置表头信息------------------*/

$objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue('A1', 'ID编号')
            ->setCellValue('B1', '月份')
            ->setCellValue('C1', '产品一')
            ->setCellValue('D1', '产品二')
            ->setCellValue('E1', '产品三');

/*--------------开始从数据库提取信息插入Excel表中------------------*/

$i=2;                //定义一个i变量,目的是在循环输出数据是控制行数
 while($rs=mysql_fetch_array($sql)){
  $rm = iconv("GB2312","UTF-8",$rs[1]);                 //对字符进行编码将数据库里GB2312的中文字符转换成UTF-8格式
      $objPHPExcel->setActiveSheetIndex(0)
            ->setCellValue("A".$i, $rs[0])
            ->setCellValue("B".$i, $rm)
            ->setCellValue("C".$i, $rs[2])
            ->setCellValue("D".$i, $rs[3])
            ->setCellValue("E".$i, $rs[4]);          

            $i++;
 }

/*--------------下面是设置其他信息------------------*/

$objPHPExcel->getActiveSheet()->setTitle('Example1');      //设置sheet的名称

 $objPHPExcel->setActiveSheetIndex(0);                            //设置sheet的起始位置

 $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');   //通过PHPExcel_IOFactory的写函数将上面数据写出来
 $objWriter->save(str_replace('.php', '.xls', __FILE__));     //设置以什么格式保存,及保存位置

至此,一个完整的将mysql数据库里的信息用PHP导出Excel实例做完,可能在运行的时候会发生一些问题,如中文乱码,表头可能显示不出来,这是因为文件编码格式的原因,将文件编码设置成UTF-8就行了,在此我就不做太多解释了。