博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
PHPExcel使用-使用PHPExcel导出文件-导出MySQL数据
阅读量:6980 次
发布时间:2019-06-27

本文共 5045 字,大约阅读时间需要 16 分钟。

现在数据库里面有一组数据,我们将它按照不同的难度进行分sheet.

首先我们需要写一个mysql的配置文件- db.config.php(utf-8编码) :

<?php

  $dbconfig= array(

    'host'        => '127.0.0.1',

    'username' => 'root',

    'password' => '',

    'database'  => 'xxx',

    'charset'    => 'utf8'

  );

?>

再创建一个php操作mysql数据库的文件 db.php(utf-8编码):

<?php

  require dirname(__FILE__).'/db.config.php'; //引入配置文件

  class db {

    public $conn = null;

    public function __construct($config){ //构造方法 实例化类时自动调用

      $this->conn = mysql_connect($config['host'],$config['username'],$config['password']) or die (mysql_error()); //链接数据库

      mysql_select_db($config['database'],$this->conn) or die (mysql_error()); //选择数据库

      mysql_query('set names '.$config['charset']) or die (mysql_error()); //设定mysql编码

    }

    public function getResult($sql){

      $resource = mysql_query($sql,$this->conn) or die (mysql_error()); //查询sql语句

      $res = array();

      while($row=mysql_fetch_assoc($resource)){

        $res[] = $row;

      }

      return $res;

    }

    public function getDataByApply($n){

      $sql = 'select id,name,description from cp_schools where apply='.$n.'order by id desc';

      $res = self::getResult($sql);

      return $res;

    }

  }

?>

准备工作差不多了,那么开始编写导出mysql数据的代码。创建文件 export.php(utf-8编码):

<?php

$dir = dirname(__FILE__); //查找当前脚本所在路径

require $dir.'/db.php'; //引入mysql操作类文件

require $dir.'/PHPExcel/PHPExcel.php'; //引入PHPExcel

$db = new db($config); //实例化db类 链接数据库

$objPHPExcel = new PHPExcel(); //实例化PHPExcel类,等同于在桌面上新建一个excel

for($i=0;$i<=3;$i++){

  //由于PHPExcel默认会创建一个序号为0的内置Sheet

  if($i>0){

    $objPHPExcel->createSheet(); //创建新的内置表

  }

  $objPHPExcel->setActiveSheetIndex($i); //把新创建的sheet设定为当前活动sheet

  $objSheet = $objPHPExcel->getActiveSheet(); //获取当前活动sheet

  $objSheet->setTitle('难度'.$i); //给当前活动sheet取个名称

  $data = $db->getDataByApply($i); //查询不同难度的院校

  $objSheet->setCellValue('A1','编号')->setCellValue('B1','名称')->setCellValue('C1','描述'); //填充数据

  $j=2;

  foreach($data as $key=>$val){

    $objSheet->setCellValue('A'.$j,$val['id'])->setCellValue('B'.$j,$val['name'])->setCellValue('C'.$j,$val['description']);

    $j++;

  }

}

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel5'); //生成excel文件

$objWriter->save($dir.'/export_mysql.xls'); //保存文件

?>

 

最后,输出至浏览器:

<?php

  require dirname(__FILE__).'db.config.php'; //引入配置文件

  class db {

    public $conn = null;

    public function __construct($config){ //构造方法 实例化类时自动调用

      $this->conn = mysql_connect($config['host'],$config['username'],$config['password']) or die (mysql_error()); //链接数据库

      mysql_select_db($config['database'],$this->conn) or die (mysql_error()); //选择数据库

      mysql_query('set names'.$config['charset']) or die (mysql_error()); //设定mysql编码

    }

    public function getResult($sql){

      $resource = mysql_query($sql,$this->conn) or die (mysql_error()); //查询sql语句

      $res = array();

      while($row=mysql_fetch_assoc($resource)){

        $res[] = $row;

      }

      return $res;

    }

    public function getDataByApply($n){

      $sql = 'select id,name,description from cp_schools where apply='.$n.'order by id desc';

      $res = self::getResult($sql);

      return $res;

    }

  }

?>

准备工作差不多了,那么开始编写导出mysql数据的代码。创建文件 export.php(utf-8编码):

<?php

$dir = dirname(__FILE__); //查找当前脚本所在路径

require $dir.'/db.php'; //引入mysql操作类文件

require $dir.'/PHPExcel/PHPExcel.php'; //引入PHPExcel

$db = new db($config); //实例化db类 链接数据库

$objPHPExcel = new PHPExcel(); //实例化PHPExcel类,等同于在桌面上新建一个excel

for($i=0;$i<=3;$i++){

  //由于PHPExcel默认会创建一个序号为0的内置Sheet

  if($i>0){

    $objPHPExcel->createSheet(); //创建新的内置表

  }

  $objPHPExcel->setActiveSheetIndex($i); //把新创建的sheet设定为当前活动sheet

  $objSheet = $objPHPExcel->getActiveSheet(); //获取当前活动sheet

  $objSheet->setTitle('难度'.$i); //给当前活动sheet取个名称

  $data = $db->getDataByApply($i); //查询不同难度的院校

  $objSheet->setCellValue('A1','编号')->setCellValue('B1','名称')->setCellValue('C1','描述'); //填充数据

  $j=2;

  foreach($data as $key=>$val){

    $objSheet->setCellValue('A'.$j,$val['id'])->setCellValue('B'.$j,$val['name'])->setCellValue('C'.$j,$val['description']);

    $j++;

  }

}

$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel,'Excel5'); //生成excel文件

browser_export('Excel5','brower_excel03.xls'); //输出到浏览器

$objWriter->save('php://output');

 

 

//输出至浏览器 代码 首先找到下载的PHPExcel->Examples->01simple-download-xls.php 或者 01simple-download-xlsx.php

//这里的两个文件分别是教会我们如何将 Excel5 和 Excel2007 输出至浏览器的代码

 

function browser_export($type,$filename){

  if($type == 'Excel5'){

  // Redirect output to a client’s web browser (Excel5)

  header('Content-Type: application/vnd.ms-excel'); //告诉浏览器将要输出excel03文件

  header('Content-Disposition: attachment;filename="'.$filename.'"'); //告诉浏览器将要输出文件的名称

  header('Cache-Control: max-age=0'); //禁止浏览器缓存

  } else if($type == 'Excel2007') {

  // Redirect output to a client’s web browser (Excel2007)

  header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'); //告诉浏览器将要输出excel07文件

  header('Content-Disposition: attachment;filename="'.$filename.'"'); //告诉浏览器将要输出文件的名称

  header('Cache-Control: max-age=0'); //禁止浏览器缓存

  }

}

?>

转载地址:http://lpjpl.baihongyu.com/

你可能感兴趣的文章
Android 中.aar文件生成方法与用法
查看>>
Vue路由history模式踩坑记录:nginx配置解决404问题
查看>>
Pyhthon爬虫其之验证码识别
查看>>
Joiner的用法
查看>>
统帅的AB面:砥砺5年重新定义中国制造
查看>>
2017手机市场半年报来袭 华为14.44%用户关注比例领跑第一阵营
查看>>
金立S10为何选择薛之谦代言?因为薛之谦一人盖过半个娱乐圈
查看>>
真假路由“易混淆” 斐讯K系列“做典范”
查看>>
华米科技Amazfit智能手表荣获2019年iF设计大奖
查看>>
点亮吉祥猪 南京城南张灯结彩迎春节
查看>>
上海张江人工智能岛“开岛” IBM首家入驻
查看>>
2019年如何确保国企效益增长?国资委明确这六项措施
查看>>
Python爬虫工作好做吗?爬虫工作发展前景如何呢?
查看>>
从程序员客栈的优秀成功案例,我们想告诉创业者什么信息?
查看>>
你一定不知道IDE里的Tomcat是怎么工作的
查看>>
Typescript 2+迷你书 :从入门到不放弃
查看>>
cms优化之晋升失败
查看>>
mybatis 批量更新
查看>>
Android studio 跟踪 Gradle Task 执行
查看>>
Java面试通关要点汇总集
查看>>