利用PHPExcel导出Excel并设置Excel格式以及数据源
发布日期:2013/07/24 分类:技术分享
代码有点长,读起来有点累。先来个截图
导出的Excel太宽了,所以将后面的列宽重新调整了再截的图
功能包括:
1、设置单元格格式,包括单元格边框、单元格高度、单元格宽度
2、合并指定的单元格
3、设置Excel数据源,并将数据源保护起来(这个是为了实现单元格下拉选项功能)
4、设置字体样式
public function export(){
- //此处全是一维数组
- $resumeState = C('RESUME_STATE');
- $processingStatus = C('PROCESSING_STATUS');
- $hunyin = C('HUNYIN');
- $sex = C('SEX');
- $AQE = C('AQE');
- //面试企业列表
- $C = M('Company');
- $company = $C->where('status=1')->field('id,title')->order($this->order)->select();
- //需要被出的数据
- $condition = $this->condition;
- $Model = $this->model;
- $Dao = M($Model);
- $list = $Dao->where($condition)->select();
- if (empty($list)){
- $this->error('没有可以导出的简历');
- }
- vendor('PHPExcel.PHPExcel');
- $fileName = $this->fileName;
- $fileName = empty($fileName)?'导出简历-'.date('Y-m-d',time()):$fileName;
- $PHPExcel = new PHPExcel();
- //设置基本信息
- $PHPExcel->getProperties()->setCreator("jecken")
- ->setLastModifiedBy("jecken")
- ->setTitle("上海**人力资源服务有限公司")
- ->setSubject("简历列表")
- ->setDescription("")
- ->setKeywords("简历列表")
- ->setCategory("");
- $PHPExcel->setActiveSheetIndex(0);
- $PHPExcel->getActiveSheet()->setTitle($fileName);
- //取得HR列表
- $hrlist = M('Admin')->field('id,nickname')->select();
- foreach ($hrlist as $key => $value){
- $hr[$value['id']] = $value['nickname'];
- }
- //存储Excel数据源到其他工作薄
- $PHPExcel->createSheet();
- $subObject = $PHPExcel->getSheet(1);
- $subObject->setTitle('data');
- foreach ($resumeState as $key => $value){
- $subObject->setCellValue('A'.$key,$value);
- }
- foreach ($processingStatus as $key => $value){
- $subObject->setCellValue('B'.$key,$value);
- }
- foreach ($company as $key => $value){
- $subObject->setCellValue('C'.($key+1),$value['title']);
- $companyList[$value['id']]=$value['title'];
- }
- $subObject->getColumnDimension('A')->setWidth(30);
- $subObject->getColumnDimension('B')->setWidth(30);
- $subObject->getColumnDimension('C')->setWidth(30);
- //保护数据源
- $subObject->getProtection()->setSheet(true);
- $subObject->protectCells('A1:C1000',time());
- //填入主标题
- $PHPExcel->getActiveSheet()->setCellValue('A1', '上海**人力资源服务有限公司');
- //填入副标题
- $PHPExcel->getActiveSheet()->setCellValue('A2', '简历列表(导出日期:'.date('Y-m-d',time()).')');
- //填入表头
- $PHPExcel->getActiveSheet()->setCellValue('A3', 'ID');
- $PHPExcel->getActiveSheet()->setCellValue('B3', '姓名');
- $PHPExcel->getActiveSheet()->setCellValue('C3', '性别');
- $PHPExcel->getActiveSheet()->setCellValue('D3', '年龄');
- $PHPExcel->getActiveSheet()->setCellValue('E3', '联系方式');
- $PHPExcel->getActiveSheet()->setCellValue('F3', '学历');
- $PHPExcel->getActiveSheet()->setCellValue('G3', '是否有AQE证书');
- $PHPExcel->getActiveSheet()->setCellValue('H3', '住址');
- $PHPExcel->getActiveSheet()->setCellValue('I3', '面试日期');
- $PHPExcel->getActiveSheet()->setCellValue('J3', '面试时间');
- $PHPExcel->getActiveSheet()->setCellValue('K3', '所属HR');
- $PHPExcel->getActiveSheet()->setCellValue('L3', '备注');
- $PHPExcel->getActiveSheet()->setCellValue('M3', '证件号码');
- $PHPExcel->getActiveSheet()->setCellValue('N3', 'QQ');
- $PHPExcel->getActiveSheet()->setCellValue('O3', '电子邮箱');
- $PHPExcel->getActiveSheet()->setCellValue('P3', '出生日期');
- $PHPExcel->getActiveSheet()->setCellValue('Q3', '婚姻状况');
- $PHPExcel->getActiveSheet()->setCellValue('R3', '户籍');
- $PHPExcel->getActiveSheet()->setCellValue('S3', '毕业时间');
- $PHPExcel->getActiveSheet()->setCellValue('T3', '毕业院校');
- $PHPExcel->getActiveSheet()->setCellValue('U3', '专业');
- $PHPExcel->getActiveSheet()->setCellValue('V3', '工作经历');
- $PHPExcel->getActiveSheet()->setCellValue('W3', '期望工作地点');
- $PHPExcel->getActiveSheet()->setCellValue('X3', '期望薪酬');
- $PHPExcel->getActiveSheet()->setCellValue('Y3', '期望职业');
- $PHPExcel->getActiveSheet()->setCellValue('Z3', '面试单位');
- $PHPExcel->getActiveSheet()->setCellValue('AA3', '面试岗位');
- $PHPExcel->getActiveSheet()->setCellValue('AB3', '目前状态');
- $PHPExcel->getActiveSheet()->setCellValue('AC3', '处理状态');
- $PHPExcel->getActiveSheet()->setCellValue('AD3', '自我评价');
- $PHPExcel->getActiveSheet()->setCellValue('AE3', '其他');
- //填入列表
- $k = 1;
- foreach ($list as $key => $value){
- $k++;
- $PHPExcel->getActiveSheet()->setCellValue('A'.($key+4), $value['id']);
- $PHPExcel->getActiveSheet()->setCellValue('B'.($key+4), $value['name']);
- //性别
- $PHPExcel->getActiveSheet()->getCell('C'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('请选择性别')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('性别')
- -> setFormula1('"'.join(',', $sex).'"');
- $PHPExcel->getActiveSheet()->setCellValue('C'.($key+4), $sex[$value['sex']]);
- //年龄
- $PHPExcel->getActiveSheet()->setCellValue('D'.($key+4), $value['age']);
- $PHPExcel->getActiveSheet()->setCellValue('E'.($key+4), $value['tel']);
- $PHPExcel->getActiveSheet()->setCellValue('F'.($key+4), $value['xueli']);
- //是否有AQE证书
- $PHPExcel->getActiveSheet()->getCell('G'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('请选择是否有AQE证书')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('是否有AQE证书')
- -> setFormula1('"'.join(',', $AQE).'"');
- $PHPExcel->getActiveSheet()->setCellValue('G'.($key+4), $AQE[$value['hasAQE']]);
- $PHPExcel->getActiveSheet()->setCellValue('H'.($key+4), $value['juzhudi']);
- $PHPExcel->getActiveSheet()->setCellValue('I'.($key+4), setDate($value['auditionTime'],'Y年m月d日'));//面试日期
- $PHPExcel->getActiveSheet()->setCellValue('J'.($key+4), setDate($value['auditionTime'],'H点i分'));//面试时间
- $PHPExcel->getActiveSheet()->setCellValue('K'.($key+4), $hr[$value['userid']]); //所属HR
- $PHPExcel->getActiveSheet()->setCellValue('L'.($key+4), $value['remark']);//备注
- $PHPExcel->getActiveSheet()->setCellValue('M'.($key+4), $value['cid']);//证件号码
- $PHPExcel->getActiveSheet()->setCellValue('N'.($key+4), $value['qq']);
- $PHPExcel->getActiveSheet()->setCellValue('O'.($key+4), $value['email']);
- $PHPExcel->getActiveSheet()->setCellValue('P'.($key+4), setDate($value['birthday']));
- //婚姻
- $PHPExcel->getActiveSheet()->getCell('Q'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('请选择婚姻')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('性别')
- -> setFormula1('"'.join(',', $hunyin).'"');
- $PHPExcel->getActiveSheet()->setCellValue('Q'.($key+4), $hunyin[$value['hunyin']]);
- $PHPExcel->getActiveSheet()->setCellValue('R'.($key+4), $value['huji']);
- $PHPExcel->getActiveSheet()->setCellValue('S'.($key+4), setDate($value['graduationTime']));
- $PHPExcel->getActiveSheet()->setCellValue('T'.($key+4), $value['graduationSchool']);
- $PHPExcel->getActiveSheet()->setCellValue('U'.($key+4), $value['specialty']);
- $PHPExcel->getActiveSheet()->setCellValue('V'.($key+4), $value['works']);
- $PHPExcel->getActiveSheet()->setCellValue('W'.($key+4), $value['expectAddress']);
- $PHPExcel->getActiveSheet()->setCellValue('X'.($key+4), $value['expectSalary']);
- $PHPExcel->getActiveSheet()->setCellValue('Y'.($key+4), $value['expectProfession']);
- //面试单位
- $PHPExcel->getActiveSheet()->getCell('Z'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('输入的值有误')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('面试单位')
- -> setFormula1('data!$C$1:$C$'.count($company));
- $PHPExcel->getActiveSheet()->setCellValue('Z'.($key+4), $companyList[$value['company']]);//面试单位
- $PHPExcel->getActiveSheet()->setCellValue('AA'.($key+4), $value['post']); //面试岗位
- //简历状态
- $PHPExcel->getActiveSheet()->getCell('AB'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('输入的值有误')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('简历状态')
- -> setFormula1('data!$A$1:$A$'.count($resumeState));
- $PHPExcel->getActiveSheet()->setCellValue('AB'.($key+4), $resumeState[$value['resumeState']]);
- //处理状态
- $PHPExcel->getActiveSheet()->getCell('AC'.($key+4))->getDataValidation()
- -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST)
- -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_INFORMATION)
- -> setAllowBlank(false)
- -> setShowInputMessage(true)
- -> setShowErrorMessage(true)
- -> setShowDropDown(true)
- -> setErrorTitle('输入的值有误')
- -> setError('您输入的值不在下拉框列表内.')
- -> setPromptTitle('处理状态')
- -> setFormula1('data!$B$1:$B$'.count($processingStatus));
- $PHPExcel->getActiveSheet()->setCellValue('AC'.($key+4), $processingStatus[$value['processingStatus']]);
- $PHPExcel->getActiveSheet()->setCellValue('AD'.($key+4), $value['selfIntroduction']);
- $PHPExcel->getActiveSheet()->setCellValue('AE'.($key+4), $value['other']);
- //设置每一行行高
- $PHPExcel->getActiveSheet()->getRowDimension($key+4)->setRowHeight(30);
- }
- //合并单元格
- $PHPExcel->getActiveSheet()->mergeCells('A1:AE1');
- $PHPExcel->getActiveSheet()->mergeCells('A2:AE2');
- //设置单元格宽度
- $PHPExcel->getActiveSheet()->getColumnDimension('A')->setWidth(6);
- $PHPExcel->getActiveSheet()->getColumnDimension('B')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('C')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('E')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('F')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('G')->setWidth(16);
- $PHPExcel->getActiveSheet()->getColumnDimension('H')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('I')->setWidth(10);
- $PHPExcel->getActiveSheet()->getColumnDimension('J')->setWidth(10);
- $PHPExcel->getActiveSheet()->getColumnDimension('K')->setWidth(10);
- $PHPExcel->getActiveSheet()->getColumnDimension('L')->setWidth(30);
- $PHPExcel->getActiveSheet()->getColumnDimension('M')->setWidth(20);
- $PHPExcel->getActiveSheet()->getColumnDimension('N')->setWidth(20);
- $PHPExcel->getActiveSheet()->getColumnDimension('O')->setWidth(25);
- $PHPExcel->getActiveSheet()->getColumnDimension('P')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('Q')->setWidth(10);
- $PHPExcel->getActiveSheet()->getColumnDimension('R')->setWidth(25);
- $PHPExcel->getActiveSheet()->getColumnDimension('S')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('T')->setWidth(18);
- $PHPExcel->getActiveSheet()->getColumnDimension('U')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('V')->setWidth(30);
- $PHPExcel->getActiveSheet()->getColumnDimension('W')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('X')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('Y')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('Z')->setWidth(20);
- $PHPExcel->getActiveSheet()->getColumnDimension('AA')->setWidth(20);
- $PHPExcel->getActiveSheet()->getColumnDimension('AB')->setWidth(20);
- $PHPExcel->getActiveSheet()->getColumnDimension('AC')->setWidth(15);
- $PHPExcel->getActiveSheet()->getColumnDimension('AD')->setWidth(30);
- $PHPExcel->getActiveSheet()->getColumnDimension('AE')->setWidth(30);
- //设置表头行高
- $PHPExcel->getActiveSheet()->getRowDimension(1)->setRowHeight(35);
- $PHPExcel->getActiveSheet()->getRowDimension(2)->setRowHeight(22);
- $PHPExcel->getActiveSheet()->getRowDimension(3)->setRowHeight(20);
- //设置字体样式
- $PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setName('黑体');
- $PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setSize(20);
- $PHPExcel->getActiveSheet()->getStyle('A1')->getFont()->setBold(true);
- $PHPExcel->getActiveSheet()->getStyle('A3:AE3')->getFont()->setBold(true);
- $PHPExcel->getActiveSheet()->getStyle('A2')->getFont()->setName('宋体');
- $PHPExcel->getActiveSheet()->getStyle('A2')->getFont()->setSize(16);
- $PHPExcel->getActiveSheet()->getStyle('A4:AE'.($k+2))->getFont()->setSize(10);
- //设置居中
- $PHPExcel->getActiveSheet()->getStyle('A1:AE'.($k+2))->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
- //所有垂直居中
- $PHPExcel->getActiveSheet()->getStyle('A1:AE'.($k+2))->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
- //设置单元格边框
- $PHPExcel->getActiveSheet()->getStyle('A3:AE'.($k+2))->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
- //设置自动换行
- $PHPExcel->getActiveSheet()->getStyle('A3:AE'.($k+2))->getAlignment()->setWrapText(true);
- //保存为2003格式
- $objWriter = new PHPExcel_Writer_Excel5($PHPExcel);
- header("Pragma: public");
- header("Expires: 0");
- header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
- header("Content-Type:application/force-download");
- header("Content-Type:application/vnd.ms-execl");
- header("Content-Type:application/octet-stream");
- header("Content-Type:application/download");
- //多浏览器下兼容中文标题
- $encoded_filename = urlencode($fileName);
- $ua = $_SERVER["HTTP_USER_AGENT"];
- if (preg_match("/MSIE/", $ua)) {
- header('Content-Disposition: attachment; filename="' . $encoded_filename . '.xls"');
- } else if (preg_match("/Firefox/", $ua)) {
- header('Content-Disposition: attachment; filename*="utf8\'\'' . $fileName . '.xls"');
- } else {
- header('Content-Disposition: attachment; filename="' . $fileName . '.xls"');
- }
- header("Content-Transfer-Encoding:binary");
- $objWriter->save('php://output');
- }
利用PHPExcel导出Excel并设置Excel格式以及数据源的更多相关文章
- Python生成文本格式的excel\xlwt生成文本格式的excel\Python设置excel单元格格式为文本\Python excel xlwt 文本格式
Python生成文本格式的excel\xlwt生成文本格式的excel\Python设置excel单元格格式为文本\Python excel xlwt 文本格式 解决: xlwt 中设置单元格样式主要 ...
- Struts2 利用AJAX 导出大数据设置遮罩层
Struts2 利用AJAX 导出大数据设置遮罩层 需求背景: 每次我们导出excel的时候 ,如果数据量很大,导出花费的时间会很长,页面却有没人任何反应,这个时候用户会认为系统有问题,要么关了页面, ...
- php利用phpexcel导出数据
php中利用phpexcel导出数据的实现代码.对phpexcel类库不熟悉的朋友,可以阅读下<phpexcel中文帮助手册>中的内容,具体实例大家可以phpexcel快速开发指南中的相关 ...
- 利用PHPExcel导出Excel相关设置
功能包括: 1.设置单元格格式,包括单元格边框.单元格高度.单元格宽度 2.合并指定的单元格 3.设置Excel数据源,并将数据源保护起来(这个是为了实现单元格下拉选项功能) 4.设置字体样式 pub ...
- 利用PHPExcel导出excel 以及利用js导出excel
导出excel的方法output_excel需要依赖PHPExcel 导出csv的方法csv_export不需要 <?php /** * @author ttt */ class ExcelCo ...
- C#导出Excel,并且设置Excel单元格格式,合并单元格.
注:要添加COM组件 Microsoft Excel 11.0 Object Library 引用. 具体代码如下: using System; using System.Collections.G ...
- 利用PHPExcel实现数据保存到excel文件
include(dirname(__FILE__) .'/phpexcel-1.7.7/Classes/PHPExcel.php'); include(dirname(__FILE__) .'/php ...
- thinkphp3.2+PHPExcel导出查询数据到excel表格的实例
首先下载PHPExcel插件,我们需要把PHPExcel.php和PHPExcel文件夹放到D:\XAMPP\htdocs\fsxb\ThinkPHP\Library\Vendor\PHPExcel目 ...
- 利用PHPExcel读取Excel的数据和导出数据到Excel
PHPExcel是一个PHP类库,用来帮助我们简单.高效实现从Excel读取Excel的数据和导出数据到Excel.也是我们日常开发中,经常会遇到的使用场景.比如有个客户信息表,要批量导出发给同事,我 ...
随机推荐
- 关于php中,记录日志中,将数组转为json信息记录日志时遇到的问题总结
1 中文编码化,无法看到具体的中文,如:你好 => \u4F60\u597D 解决方案:可以使用 json_encode($arr,JSON_UNESCAPED_UNICODE) 转义中文[ ...
- thinkinginjava学习笔记10_容器
Java中并没有像Perl.Python.Ruby那样对容器有直接的支持,但是可以依靠容器类来完成相同的工作: 泛型 使用一个ArrayList对象可以保存一系列的对象,如: ArrayList ap ...
- 第五章 MVC之Bundle详解
一.简述 Bundle,英文原意就是捆.收集.归拢.在MVC中的Bundle技术,也就是一个对css和js文件的捆绑压缩的技术. 它的用处: 将多个请求捆绑为一个请求,减少服务器请求数 压缩javas ...
- Nginx集群之WCF分布式消息队列
目录 1 大概思路... 1 2 Nginx集群之WCF分布式消息队列... 1 3 MSMQ消息队列... 2 4 编写WCF服务.客户端程序... ...
- C++\virtual 虚函数、纯虚函数
前提摘要: 虚函数联系到多态,多态联系到继承.所以本文中都是在继承层次上做文章.没了继承,什么都没得谈. 虚函数定义: 指向基类的指针或引用在操作它的多态类(子类/派生类)对象时,会根据不同的类对象, ...
- Core Animation文档翻译 (第一篇)
Core Animation 文档翻译(第一篇) 前言 作为iOS 开发,官方文档的阅读是很有必要的,值此周末便写下此文.作为iOS 实际经验3年的开发,之前有阅读并实践过经典的<iOS核心动画 ...
- css的常用效果总结
1.模糊遮罩效率,模糊滤镜效果 -webkit-filter: blur(3px); -moz-filter: blur(3px); -o-filter: blur(3px); -ms-filter: ...
- .Net程序员学用Oracle系列:视图、函数、存储过程、包
1.视图 在实际操作过程中,本人发现 Oracle 视图定义有一个缺陷,就是不大方便注释,每次写好的注释执行之后再打开视图定义所有注释就全都没了.后来我发现把注释写到末尾就不会被清除,但这样总感觉乖乖 ...
- 咫尺论坛|即速应用-微信小程序社区
咫尺论坛|即速应用-微信小程序社区 是一个集微信和支付宝小程序行业资讯.开发资源.技术交流于一身的大型小程序开发论坛,成立伊始便迅速聚集了一大批小程序开发爱好者,短时间内成为了国内领先的小程序开发者社 ...
- Oracle 11G Client 安装就可以用上Oracle11G啦,不用傻傻的安装2G多的Oracle啦,安装特别简单,使用起来更简单
下载地址: http://download.oracle.com/otn/nt/oracle11g/112010/win32_11gR2_client.zip 先将下载下来的ZIP文件解压,并运行se ...