PHPExcel使用-使用PHPExcel导出文件-导出MySQL数据
现在数据库里面有一组数据,我们将它按照不同的难度进行分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'); //禁止浏览器缓存
}
}
?>
PHPExcel使用-使用PHPExcel导出文件-导出MySQL数据的更多相关文章
- PHP导出MySQL数据到Excel文件
PHP导出MySQL数据到Excel文件 转载 常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存 ...
- linux下导入、导出mysql数据库命令 下载文件到本地
一.下载到本地 yum install lrzsz sz filename 下载 rz filename 上传 linux下导入.导出mysql数据库命令 一.导出数据库用mysqldump命 ...
- navicat如何导出mysql数据表结构
我们在创建数据库时会对字段进行设置,比如类型.长度等,如果字段多的话一个个设置非常麻烦,可以从其他地方已有的表导入数据表结构,怎么操作呢?我们拿navicat导出mysql数据表结构为例: 1.点击“ ...
- PHP导出MySQL数据到Excel
经常会碰到需要从数据库中导出数据到Excel文件,用一些开源的类库,比如PHPExcel,确实比较容易实现,但对大量数据的支持很不好,很容易到达PHP内存使用上限.这里的方法是利用fputcsv写CS ...
- linux、windows下导入、导出mysql数据库命令
一.导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径): 1.导出数据和表结构:[不是mysql里的命令]mysqldump -u用户名 -p密码 数据库名 > 数据 ...
- linux下导入、导出mysql数据库命令
一.导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径): 1.导出数据和表结构: mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql #/usr ...
- (转)linux下导入、导出mysql数据库命令
原文链接:http://www.xiaohuai.com/2902 一.导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径):1.导出数据和表结构:mysqldump -u用 ...
- linux下导入、导出mysql数据库命令的实现方法
首先建空数据库 mysql>create database abc; 导入数据库 mysql>use abc; 设置数据库编码 mysql>set names utf8; 导入数据( ...
- linux下导入、导出mysql 数据库命令
一.导出数据库用mysqldump命令(注意mysql的安装路径,即此命令的路径):1.导出数据和表结构:mysqldump -u用户名 -p密码 数据库名 > 数据库名.sql#/usr/lo ...
随机推荐
- 转:git windows中文目录乱码问题解决
Git的Windows版本Msysgit对中文的支持不够好 当使用时,会出现以下三种情况的中文乱码: 1.ls不能显示中文目录 解决办法:在git/git-completion.bash中增加一行: ...
- QT之 Hello World
下载…… 我下载的Qt creater 版本为4.2.1,Qt版本为5.8.0 打开QT Creater 1. 新建项目 New Project -> Application -> Q ...
- 推荐系统之基于图的推荐:基于随机游走的PersonalRank算法
转自http://blog.csdn.net/sinat_33741547/article/details/53002524 一 基本概念 基于图的模型是推荐系统中相当重要的一种方法,以下内容的基本思 ...
- springbatch---->springbatch的使用(四)
这里我们重点学习一下springbatch里面的各种监听器的使用,以及job参数的传递.追求得到之日即其终止之时,寻觅的过程亦即失去的过程. springbatch的监听器 一.JOB LISTENE ...
- 【Spring Boot&& Spring Cloud系列】单点登录SSO概述
概念 单点登录(Singleton Sign On),简称为SSO,是目前比较流行的企业业务整合的解决方案之一.SSO的定义是在多个应用系统中,用户只需要登录一次就能访问所有相互信任的应用系统. 也就 ...
- 关于array.sort(array,array)
// 基于第一个 System.Array 中的关键字,使用每个关键字的 System.IComparable 实现,对两个一维 System.Array // 对象(一个包含关键字,另一个包含对应的 ...
- android studio 引用远程仓库下载慢(JCenter下载慢)的办法
https://blog.csdn.net/linglingchenchen/article/details/62236723 解决android studio引用远程仓库下载慢(JCenter下载慢 ...
- LeetCode 77 Combinations(排列组合)
题目链接:https://leetcode.com/problems/combinations/#/description Problem:给两个正数分别为n和k,求出从1,2.......n这 ...
- sencha touch 扩展官方NavigationView 灵活添加按钮组,导航栏,自由隐藏返回按钮(2014-5-15)
扩展视频讲解:http://www.cnblogs.com/mlzs/p/3652094.html官方NavigationView详解:http://www.cnblogs.com/mlzs/p/35 ...
- mint下截图工具shutter的安装和使用设置
[原创作品,技术交流.允许转载,转载时请务必以超链接形式标明文章原始出处 .作者信息.如有错误,请指正] /** author: lihaibo date: 1/25/2016 */ 今天安装了双系统 ...