当前位置: 首页 > 编程日记 > 正文

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'); //禁止浏览器缓存

  }

}

?>

相关文章:

C语言清空输入缓冲区的N种方法对比

C语言中有几个基本输入函数&#xff1a; //获取字符系列 int fgetc(FILE *stream); int getc(FILE *stream); int getchar(void); //获取行系列 char *fgets(char * restrict s, int n, FILE * restrict stream); char *gets(char *s);//可能导致溢出&#xff0c;用fgets代替之…

低耗时、高精度,微软提基于半监督学习的神经网络结构搜索算法

作者 | 罗人千、谭旭、王蕊、秦涛、陈恩红、刘铁岩 来源 | 微软研究院AI头条&#xff08;ID:MSRAsia&#xff09;编者按&#xff1a;近年来&#xff0c;神经网络结构搜索&#xff08;Neural Architecture Search, NAS&#xff09;取得了较大的突破&#xff0c;但仍然面临搜索耗…

《虚拟化与云计算》读书感(三)数据中心的概述

看了《虚拟化与云计算》的第一章第一节‘数据中心的概述’。在我读这一节开始&#xff0c;我看到这个题目的时候总是联想到类似谷歌数据中心一类的东西&#xff0c;多个硬盘或者服务器的堆叠。然后整来几个集装箱把这些堆叠的服务器塞进去&#xff0c;然后供用户使用。然而自从…

golang笔记——struct

1、定义一个结构体 type User struct {userid intusername stringpassword string } 2、初始化一个结构体 有两种情况&#xff0c;一是得到结构体的对象&#xff0c;一是得到结构的对象指针&#xff0c;分别有三种方式&#xff1a; //第1种方式&#xff0c;先声明对象&#x…

posix_memalign

翻译的<Linux system programming> 第八章 二 ;《Linux System Programming》中文版 对齐 数据的对齐(alignment)是指数据的地址和由硬件条件决定的内存块大小之间的关系。一个变量的地址是它大小的倍数的时候&#xff0c;这就叫做自然对齐(naturally aligned)。例如&…

ubuntu 10.04 安装eclipse及其中文语言包

1.安装eclipsesudo apt-get install eclipse2.暗自中文语言包点 击下载中文语言包&#xff08;http://www.eclipse.org/downloads/download.php?file /technology/babel/babel_language_packs/BabelLanguagePack-eclipse- zh_3.5.0.v20091121043401.zip&urlhttp://d2u376u…

世界顶级赛事百万座位如何做到票务限时匹配?

作者 | 阿里文娱技术专家 展恒出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;背景麦座&#xff0c;是大麦旗下的票务系统。去年&#xff0c;我们承接了 2019 年国际篮联篮球世界杯&#xff08;2019FBWC&#xff09;&#xff0c; 核心目标是完成三种套票的运营及售卖…

[转](不理想)Ubuntu下更改主显示器

参考链接&#xff1a;http://www.cnblogs.com/feng_013/archive/2012/03/05/2380111.html 查看显示器信息&#xff1a; fdmfdm-OptiPlex-780:~$ xrandr 设置主显示器 fdmfdm-OptiPlex-780:~$ xrandr --output HDMI1 --auto --primary 设置副显示器在主显示器右边 fdmfdm-OptiPl…

Nginx源码分析--数据对齐posix_memalign和memalign函数

posix_memalign函数() /* * 背景&#xff1a; * 1&#xff09;POSIX 1003.1d * 2&#xff09;POSIX 标明了通过malloc( ), calloc( ), 和 realloc( ) 返回的地址对于 * 任何的C类型来说都是对齐的 * 功能&#xff1a;由posix_memalign分配的内存空间&…

不要一辈子靠技术生存

今天看了一篇文章,感受挺深的,人的一生不能一辈子靠技术生存,尽管你的技术能力很强.(文章转载出处忘记,有哪位朋友知道的提醒一下)一、 在中国你千万不要因为学习技术就可以换来稳定的生活和高的薪水待遇&#xff0c;你千万更不要认为哪些从事 市场开发&#xff0c;跑腿的人&am…

中国顶尖的技术社区们在一个群里,会聊什么…

* 文中表情包图片来自网络

矩阵中路径数目问题

在如下8*6的矩阵中&#xff0c;请计算从A移动到B一共有____种走法。要求每次只能向上或向右移动一格&#xff0c;并且不能经过P。 8*6的矩阵&#xff0c;从左下角A到右上角B&#xff0c;一共需要走12步&#xff0c;其中5步向上&#xff0c;7步向右&#xff0c;因此总的走法一共…

RANet : 分辨率自适应网络效果和性能的best trade-off | CVPR 2020

作者 | VincentLee来源 | 晓飞的算法工程笔记简介深度CNN带来了性能提升的同时也带来了过高的计算量&#xff0c;许多研究放在了如何进行网络加速上面&#xff0c;其中比较直接的是根据样本难易程度进行自动调整的自适应网络。基于对自适应网络的研究&#xff0c;论文提出了自适…

strcpy,memcpy和memmove区别

strcpy和memcpy都是标准C库函数&#xff0c;它们有下面的特点。 strcpy提供了字符串的复制。即strcpy只用于字符串复制&#xff0c;并且它不仅复制字符串内容之外&#xff0c;还会复制字符串的结束符。 已知strcpy函数的原型是&#xff1a;char* strcpy(char* dest, const cha…

WinForm 读写配置文件

读配置文件 方法(1) //ConfigurationManager.RefreshSection("appSettings");stringsettingValue ConfigurationManager.AppSettings.Get("setting1");读配置文件 方法(2) Configuration config ConfigurationManager.OpenExeConfiguration(ConfigurationU…

PHP 读取数据库内容并以二维数组按指定列输出实例

最新PHP 读取数据库内容并以二维数组按指定列输出实例以下是三零网为大家整理的最新PHP 读取数据库内容并以二维数组按指定列输出实例的文章&#xff0c;希望大家能够喜欢!<?php$host "localhost"; //主机名$user "root"; //mysql用户名$passwor…

指针的本质2-void和void*及其应用在nginx中的应用

指针本质论指针有两个属性:指向变量/对象的地址和长度。 但是指针只存储地址,长度则取决于指针的类型&#xff0c;编译器根据指针的类型从指针指向的地址向后寻址&#xff0c; 指针类型不同则寻址范围也不同&#xff0c;比如: int*从指定地址向后寻找4字节作为变量的存储单元&…

首次揭秘!大麦如何应对超大规模高性能选座抢票?

作者| 阿里文娱技术专家恒磊、高级开发工程师新钱出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09;背景介绍随着现场娱乐行业的不断发展&#xff0c;各类演出层出不穷&#xff0c;越来越多的演出开启选座购票满足用 户的自主选座需求。大麦的选座不仅面向中小场馆类的…

华为交换机密码恢复

华为交换机密码恢复说明&#xff1a;以下方法将删除原有config文件&#xff0c;使设备恢复到出厂配置。在设备重启时按CtrlB进入BOOT MENU之后&#xff0c;Press Ctrl-B to enter Boot Menu... 5Password : 缺省为空&#xff0c;回车即可1. Download application file to flash…

nginx源码分析--内存对齐处理

1.nginx内存对齐主要是做2件事情&#xff1a; 1) 内存池的内存地址对齐&#xff1b; 2) 长度按照2的幂取整.因为前面结构体已经是对齐了&#xff0c;如果后面的内存池每一小块不是2的幂&#xff0c;那么后面的就不能对齐 2.通用内存对齐理论 内存对齐&#xff1a;数据项只能…

七喜携手AMD,摆脱英特尔“潜规则”

七喜携手AMD&#xff0c;摆脱英特尔“潜规则”<?xml:namespace prefix o ns "urn:schemas-microsoft-com:office:office" />最近&#xff0c;在PC市场随着七喜董事副总裁毛骏飙揭发英特尔制定的潜规则&#xff0c;“游戏规则都是英特尔制定的&#xff0c;全…

半小时训练亿级规模知识图谱,亚马逊AI开源知识图谱嵌入表示框架DGL-KE

出品 | AI科技大本营&#xff08;ID:rgznai100&#xff09; 知识图谱 &#xff08;Knowledge Graph&#xff09;作为一个重要的技术&#xff0c;在近几年里被广泛运用在了信息检索&#xff0c;自然语言处理&#xff0c;以及推荐系统等各种领域。学习知识图谱的嵌入表示 &#x…

数组的各类排序

1 package sort;2 3 /**4 * 数组的各种排序操作5 * Created by liuwei on 16/3/6.6 */7 public class MSort {8 9 /**10 * 直接插入排序11 * 外层一个循环,从第2个元素开始(下标为1),遍历后面的所有元素12 * 内层一个循环,从当前位置position i 开始,每次…

Virtualbox安装使用注意

1.VirtualBox升级到4.3以后不能打开 提示创建 COM 对象失败 应用程序将被中断 解决方案&#xff1a;右键VirtualBox的桌面快捷方式&#xff0c;选择属性&#xff0c;选到兼容性选项卡&#xff0c;勾选“以兼容模式运行这个程序”&#xff0c;下拉框选择Windows Server 2008 …

机器学习项目模板:ML项目的6个基本步骤

来源 | DeepHub IMBA每个机器学习项目都有自己独特的形式。对于每个项目&#xff0c;都可以遵循一组预定义的步骤。尽管没有严格的流程&#xff0c;但是可以提出一个通用模板。准备问题不仅是机器学习&#xff0c;任何项目的第一步都是简单地定义当前的问题。您首先需要了解背景…

ib_logfile 在数据库中有何作用?

ib_logfile 在数据库中有何作用&#xff1f; ib_logfile0/ib_logfile1 文件在数据库中起什么作用&#xff1f; 如果被删除&#xff0c;对数据库有何影响&#xff1f; ----->>>>>>>>>>> 回复 #1 mugua_xinli 的帖子 用于存放InnoDB引擎的事…

Podfile 常见语法

source URL &#xff1a; 指定镜像仓库的源 platform : ios, 6.0 &#xff1a; 指定所支持系统和最低版本 inhibit_all_warnings! &#xff1a;屏蔽所有warning workspace 项目空间名&#xff1a; 指定项目空间名 xcodeproj 工程文件名&#xff1a;指定xcodeproj工程文件名 …

今天学完了ccna

通过10天的学习&#xff0c;终于学完了NA&#xff0c;但是会不会呢&#xff1f;还是个未知数&#xff0c;再就也一知半解的。觉得基础知识太差了&#xff0c;可是看书&#xff0c;又觉得太长了&#xff0c;太多了&#xff0c;晚上老是停电 白天啥也看不进去。热。还是静不下心&…

攀登数据科学家和数据工程师之间的隔墙

来源 | 数据派 THU机器学习的教育和研究重点往往集中在数据科学过程的模型构建、训练、测试和优化等方面。要使这些模型投入使用&#xff0c;需要一套工程专长和组织结构&#xff0c;对于其中的标准尚不存在。有一个架构可以指导数据科学和工程团队相互协作&#xff0c;从而将机…

js变量以及其作用域详解

2019独角兽企业重金招聘Python工程师标准>>> 一、变量的类型 Javascript和Java、C这些语言不同&#xff0c;它是一种无类型、弱检测的语言。它对变量的定义并不需要声明变量类型&#xff0c;我们只要通过赋值的形式&#xff0c;可以将各种类型的数据赋值给同一个变…