php导出表格两种方法 ——PhpExcel的列子
php常用的导出表格有两种方法,第一种是输出表格,这种方法打开的时候有警告提示,一般导出表格会用phpexcel,这个导出比较灵活,而且还可以设置表格的样式。
第一种导出例子
/**
* 执行导出
* @param unknown $result 数据源
*/
function Excel($result,$fileName='',$Key=''){
$fileName = iconv('utf-8', 'gbk',$fileName);
header("Content-type:text/html;charset=utf-8");
header("Content-type:application/octet-stream");
header("Accept-Ranges:bytes");
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:attachment;filename=$fileName".date("Y-m-d").".xls");
header("Pragma: no-cache");
header("Expires: 0");
//第一行显示key
if(!$Key){
$Key = array("姓名 ","性别 ","手机号 ","意向车型 ","购买计划","提交时间");
}
echo iconv('utf-8', 'gbk', implode("\t", $Key))."\n";
//第三行显示剩余val
foreach($result as $key=>$val){
echo iconv('utf-8', 'gbk', implode("\t", $val))."\n";
}
}
第二种导出使用phpexcel
/**
* 导出数据(生成excel)
* @param $data excel第一行数据
* 例:1、array('字段' => '1');
* @param $list 二维数组 导出的数据
* @param string $title 工作表名称
* @param string $filename 文件名称
* @return boolean
*/
public function output1($data , $list , $title = '数据模板' , $filename = '数据模板'){
$count = count($data);//数组长度
if(!is_array($data) || $count > $this->maxstr){//数据是否符合要求
return false;
}
// Create new PHPExcel object
$objPHPExcel = new \PHPExcel();
// Set document properties
$objPHPExcel->getProperties()->setCreator("Maarten Balliauw")
->setLastModifiedBy("Maarten Balliauw")
->setTitle("Office 2007 XLSX Test Document")
->setSubject("Office 2007 XLSX Test Document")
->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.")
->setKeywords("office 2007 openxml php")
->setCategory("Test result file");
// Add some data 第一行
// 添加一些数据 第一行
$SheetIndex = $objPHPExcel->setActiveSheetIndex(0);
$this->setAttendance($SheetIndex);//写入数据
//设置第一个单元格样式
$obActiveSheet = $objPHPExcel->getActiveSheet();
//设置高度
$obActiveSheet->getRowDimension('1')->setRowHeight(40);
$obActiveSheet->getRowDimension('6')->setRowHeight(100);
$obActiveSheet->getRowDimension('7')->setRowHeight(90);
$obActiveSheet->getRowDimension('8')->setRowHeight(90);
$obActiveSheet->getRowDimension('9')->setRowHeight(90);
$obActiveSheet->getRowDimension('10')->setRowHeight(80);
$obActiveSheet->getRowDimension('17')->setRowHeight(20);
$obActiveSheet->getRowDimension('18')->setRowHeight(30);
$obActiveSheet->getRowDimension('19')->setRowHeight(30);
//设置宽度
$obActiveSheet->getColumnDimension('A')->setWidth(12);
$obActiveSheet->getColumnDimension('B')->setWidth(18);
$obActiveSheet->getColumnDimension('C')->setWidth(15);
$obActiveSheet->getColumnDimension('D')->setWidth(15);
$obActiveSheet->getColumnDimension('E')->setWidth(15);
$obActiveSheet->getColumnDimension('H')->setWidth(15);
//导出
$this->outputPHPExcel($objPHPExcel, $filename);
}
/**
* 考勤数据写入
* @param $SheetIndex 单元格对象
* @param $Cycle 周期数据列表
* @param $_clock 员工考勤数据
* @return number 返回当前最大行数
*/
private function setAttendance($SheetIndex){
$c = 1;
/** ----------------------------考勤头部开始--------------------------------------- */
$chrA = chr($this->asciiA + 0);//A
$chrB= chr($this->asciiA + 1);//B
$chrC= chr($this->asciiA + 2);//C
$chrD= chr($this->asciiA + 3);//D
$chrE= chr($this->asciiA + 4);//E
$chrF= chr($this->asciiA + 5);//F
$chrG= chr($this->asciiA + 6);//G
$chrH= chr($this->asciiA + 7);//G
$chrI= chr($this->asciiA + 8);//G
$chrJ= chr($this->asciiA + 9);//G
$chrK= chr($this->asciiA + 10);//G
$chrL= chr($this->asciiA + 11);//G
$chrM= chr($this->asciiA + 12);//G
$chrN= chr($this->asciiA + 13);//G
$chrO= chr($this->asciiA + 14);//G
$SheetIndex->setCellValueExplicit($chrA.($c), '岗位考核模板');
$SheetIndex->mergeCells($chrA.($c).':'.$chrO.($c));//合并单元格 A2,A3
$SheetIndex->setCellValueExplicit($chrA.($c+1), '被考核人');
$SheetIndex->mergeCells($chrA.($c+1).':'.$chrA.($c+2));//合并单元格 A2,A3
$SheetIndex->setCellValueExplicit($chrB.($c+1), '姓名');
$SheetIndex->setCellValueExplicit($chrB.($c+2), '职务');
$SheetIndex->setCellValueExplicit($chrC.($c+1), 'xxx');
$SheetIndex->setCellValueExplicit($chrD.($c+1), '部门');
$SheetIndex->setCellValueExplicit($chrD.($c+2), '入职时间');
$SheetIndex->setCellValueExplicit($chrE.($c+1), '网站开发部');
$SheetIndex->mergeCells($chrE.($c+1).':'.$chrG.($c+1));//合并单元格
$SheetIndex->mergeCells($chrE.($c+2).':'.$chrG.($c+2));//合并单元格
$SheetIndex->setCellValueExplicit($chrH.($c+1), '被考核人主管');
$SheetIndex->mergeCells($chrH.($c+1).':'.$chrI.($c+1));//合并单元格
$SheetIndex->mergeCells($chrH.($c+2).':'.$chrI.($c+2));//合并单元格
$SheetIndex->setCellValueExplicit($chrJ.($c+1), '姓名');
$SheetIndex->setCellValueExplicit($chrJ.($c+2), '职务');
$SheetIndex->setCellValueExplicit($chrK.($c+1), 'xxx);
$SheetIndex->mergeCells($chrK.($c+1).':'.$chrO.($c+1));//合并单元格
$SheetIndex->mergeCells($chrK.($c+2).':'.$chrO.($c+2));//合并单元格
$SheetIndex->mergeCells($chrA.($c+3).':'.$chrO.($c+3));//合并单元格
//第5行
$SheetIndex->setCellValueExplicit($chrA.($c+4), '序号');
$SheetIndex->setCellValueExplicit($chrB.($c+4), '指标名称');
$SheetIndex->setCellValueExplicit($chrC.($c+4), '权重');
$SheetIndex->setCellValueExplicit($chrD.($c+4), '衡量方法');
$SheetIndex->setCellValueExplicit($chrM.($c+4), '评定');
$SheetIndex->setCellValueExplicit($chrN.($c+4), '评分');
$SheetIndex->setCellValueExplicit($chrO.($c+4), '最终得分');
$SheetIndex->mergeCells($chrD.($c+4).':'.$chrL.($c+4));//合并单元格
//第6行
$SheetIndex->setCellValueExplicit($chrA.($c+5), '1');
$SheetIndex->setCellValueExplicit($chrB.($c+5), '工作完成度');
$SheetIndex->setCellValueExplicit($chrC.($c+5), '30%');
$SheetIndex->setCellValueExplicit($chrD.($c+5), "A+:测试没有崩溃、严重并且无高级别bug
A:测试没有崩溃、严重并且高级别bug控制在所有bug的1%以内,中级别bug控制在10%
100:测试没有崩溃、严重并且高级别bug控制在所有bug的2%以内,中级别bug控制在20%
B :测试没有崩溃、严重并且高级别bug控制在所有bug的5%,使用方反馈系统中出现文案、兼容性等对系统造成较小影响的bug
B-: 有崩溃严重bug或者无奔溃严重bug但是有5%以上的高级别bug,使用方反馈在使用中出现功能无法使用、500、404等严重故障");
$SheetIndex->setCellValueExplicit($chrM.($c+5), '100');
$SheetIndex->setCellValueExplicit($chrN.($c+5), '100');
$SheetIndex->setCellValueExplicit($chrO.($c+5), '30');
$SheetIndex->mergeCells($chrD.($c+5).':'.$chrL.($c+5));//合并单元格
}
这只是部分代码
php导出表格两种方法 ——PhpExcel的列子的更多相关文章
- oracle数据的导入导出(两种方法三种方式)
大概了解数据库中数据的导入导出.在oracle中,导入导出数据的方法有两种,一种是使用cmd命令行的形式导入导出数据,另一种是使用PL/SQL工具导入导出数据. 1,使用cmd命令行导入导出数据 1. ...
- 关于Java中excel表格导出的总结(Java程序导出模板和Java根据模板导出表格两种实现方式)
导出excel通用模板(程序定义模板导出) 转载原文:https://www.jianshu.com/p/5c7b359a159c 如下代码,本方法主要用于程序定义模板格式,并导出文件.该方法将定义和 ...
- SQL2008全部数据导出导入两种方法【转】
方法一:生成脚本导出导入sql2008全部数据 第一步,右键要导出的数据库,任务--生成脚本 第二步,在设置脚本编写选项处,点击--高级(A),选择要编写脚本的数据的类型为:架构和数据 如果找 ...
- SQL2008全部数据导出导入两种方法
方法一:生成脚本导出导入sql2008全部数据第一步,右键要导出的数据库,任务--生成脚本 第二步,在设置脚本编写选项处,点击--高级(A),选择要编写脚本的数据的类型为:架构和数据 如果找不到 要编 ...
- SQL2008所有数据导出导入两种方法
方法一:生成脚本导出导入sql2008所有数据 第一步.右键要导出的数据库.任务--生成脚本 第二步,在设置脚本编写选项处,点击--高级(A),选择要编写脚本的数据的类型为:架构和数据 假设找不到 要 ...
- AE 将地图导出为图片的两种方法
在ArcGIS的开发中,我们经常需要将当前地图打印(或是转出)到图片文件中.将Map或Layout中的图象转出有两种方法,一种为通过IActiveView的OutPut函数,另外一种是通过IExpor ...
- js如何实现动态的在表格中添加和删除行?(两种方法)
js如何实现动态的在表格中添加和删除行?(两种方法) 一.总结 1.table元素有属性和一些方法(js使用) 方法一:添加可通过在table的innerHTML属性中添加tr和td来实现 tab.i ...
- html中如何实现表格移入移出时背景颜色改变?(两种方法)
html中如何实现表格移入移出时背景颜色改变?(两种方法) 一.总结 1.通过css的table标签的hover属性: 10 #tab:hover{ 11 background: green 12 } ...
- js如何动态创建表格(两种方法)
js如何动态创建表格(两种方法) 一.总结 一句话总结: 1.方法一:写好创建表格的html代码,将之赋值给div的innerHTML. 2.方法二.直接用创建好的table元素的方法insertRo ...
随机推荐
- 机器学习之挖掘melb_data.csv数据
mel_data.csv是关于melb地区房屋的数据 mel_data.csv import pandas as pd melbourne_file_path = "E:\data\Melb ...
- netcore 版本 切换 sdk
https://docs.microsoft.com/zh-cn/dotnet/core/tools/global-json
- Opencv颜色识别与追踪
这是基于颜色识别的物体追踪 不废话 直接看代码 这是Opencv3的代码 //---------------------------------[头文件.命名空间包含部分]-------------- ...
- C语言词法分析中的贪心算法
C语言词法分析中的贪心算法 当我们写出a---b这种语句的时候我们应该考虑C语言的编译器是如何去分析这条语句的. C语言对于解决这个问题的解决方案可以归纳为一个很简单的规则:每一个符号应该包含尽可能多 ...
- java之hiberante之集合映射之list映射
这篇讲解 集合映射之List映射 1.通常对于集合,在hibernate中的处理都是使用set来完成.但是hibernate也提供了对于其他几种集合的映射. 在这里实现List的映射,List是有序的 ...
- docker容器的使用整理
2019/10/24, docker 19.03.4 摘要:docker容器常用命令整理 gitbooks文档 docker脚本安装 使用官方脚本安装docker,从阿里云下载: curl -fsSL ...
- 二 python并发编程之多进程实现
一 multiprocessing模块介绍 二 process类的介绍 三 process类的使用 四 守护进程 五 进程同步(锁) 六 队列 七 管道 八 共享数据 九 信号量 十 事件 十一 进程 ...
- unity shader入门(四):高光
高光反射计算公式(phong模型)Cspecular=(Clight*Mspecular)max(0,v*r)mgloss mgloss为材质的官泽度,也成反射度,控制高光区域亮点有多大 Mspecu ...
- [LeetCode] 647. 回文子串 ☆☆☆(最长子串、动态规划、中心扩展算法)
描述 给定一个字符串,你的任务是计算这个字符串中有多少个回文子串. 具有不同开始位置或结束位置的子串,即使是由相同的字符组成,也会被计为是不同的子串. 示例 1: 输入: "abc" ...
- 【OGG】RAC环境下配置OGG单向同步 (四)
[OGG]RAC环境下配置OGG单向同步 (四) 一.1 BLOG文档结构图 一.2 前言部分 一.2.1 导读 各位技术爱好者,看完本文后,你可以掌握如下的技能,也可以学到一些其它你所不知道的 ...