利用PHPExcel导出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');
}
来源:http://www.thinkphp.cn/topic/3739.html
利用PHPExcel导出Excel相关设置的更多相关文章
- 利用PHPExcel导出Excel并设置Excel格式以及数据源
浏览:23969 发布日期:2013/07/24 分类:技术分享 代码有点长,读起来有点累.先来个截图 导出的Excel太宽了,所以将后面的列宽重新调整了再截的图 功能包括: 1.设置单元格格式,包括 ...
- 利用PHPExcel导出excel 以及利用js导出excel
导出excel的方法output_excel需要依赖PHPExcel 导出csv的方法csv_export不需要 <?php /** * @author ttt */ class ExcelCo ...
- 利用PHPExcel读取Excel的数据和导出数据到Excel
PHPExcel是一个PHP类库,用来帮助我们简单.高效实现从Excel读取Excel的数据和导出数据到Excel.也是我们日常开发中,经常会遇到的使用场景.比如有个客户信息表,要批量导出发给同事,我 ...
- 利用PHPExcel 实现excel数据的导入导出(源码实现)
利用PHPExcel 实现excel数据的导入导出(源码实现) 在开发过程中,经常会遇到导入导出的需求,利用phpexcel类实现起来也是比较容易的,下面,我们一步一步实现 提前将phpexcel类下 ...
- 利用Servlet导出Excel
-----因为Excel可以打开HTML文件,因此可以利用页面的Form表单把页面中的table内容提交给Servlet,然后后台把提交上来的table内容转换成文件流的形式,并以下载的形式转给客户端 ...
- phpExcel导出excel加超级链接的实例代码[转]
phpexcel实现的导出excel文件的代码,且可以在excel文件中加入超级链接. 说明:PHPExcel的开发包Tests目录有详细使用实例.以下代码支持中文,注意文件编码,文件保存为utf-8 ...
- Struts2 利用AJAX 导出大数据设置遮罩层
Struts2 利用AJAX 导出大数据设置遮罩层 需求背景: 每次我们导出excel的时候 ,如果数据量很大,导出花费的时间会很长,页面却有没人任何反应,这个时候用户会认为系统有问题,要么关了页面, ...
- php利用phpexcel导出数据
php中利用phpexcel导出数据的实现代码.对phpexcel类库不熟悉的朋友,可以阅读下<phpexcel中文帮助手册>中的内容,具体实例大家可以phpexcel快速开发指南中的相关 ...
- PHPExcel导出excel文件
今天园子刚开,先来个货顶下,后续园丁qing我会再慢慢种园子的,希望大家多来园子逛逛. PHPExcel导出excel文件,先说下重要的参数要记住的东西 impUser() 导入方法 exportEx ...
随机推荐
- ubuntu下gcc-avr安装
ubuntu下研究arduino时发现,原来可以不用arduino IDE开发,linux下还有gcc-avr直接开发avr系列的控制器. 于是,迫不及待的查看了下相关资料,总结一下安装gcc-avr ...
- 【Android】8.1 主题基本用法
分类:C#.Android.VS2015: 创建日期:2016-02-17 一.创建本章示例主界面 1.界面截图 2.MainActivity.cs文件中对应的代码 在CreateChItems()方 ...
- 深入理解node.js的module.export 和 export方法的区别
你肯定非常熟悉nodejs模块中的exports对象,你可以用它创建你的模块.例如:(假设这是rocker.js文件) exports.name = function() { console.log( ...
- ng-bind和{{}}插值法
引言 今天调bug的时候遇到了一个问题,就是有的时候加载出来的数据没有数据的时候出现的是{{TeacherName}},一看这个不是我在页面上绑的值吗?怎么这样就显示出来了呢…… 针对这个问题,想起来 ...
- webstrom中的快捷键
1. ctrl + shift + n: 打开工程中的文件,目的是打开当前工程下任意目录的文件. 2. ctrl + j: 输出模板 3. ctrl + b: 跳到变量申明处 4. ctrl + al ...
- java jsp失效问题--待解决
打印jps错误信息jps -J-Djps.debug=true -J-Djps.printStackTrace=true 未完待续...
- Windows server 2012公用网络修改为专用网络
普通环境路径如下: [控制面板]--[系统和安全]--[管理工具]--[本地安全策略]--[网络列表管理器策略]--[网络]--[网络位置],设定之后也可以设定一下[用户权限] 域控环境路径如下: 不 ...
- 【Java】ParseInt方法
parseInt()方法首先查看位置0处的 字符,判断它是否是个有效数字:如果不是,该方法将返回NaN,不再继续执行其他操作.但如果该字符是有效数字,该方法将查看位置1处的字符,进行同样的 测试.这一 ...
- response.setContentType 与response.setCharacterEncoding
response.setContentType 设置发送到客户端的响应的内容类型,可以包括字符编码说明. 也就是说在服务器端坐了这个设置,那么他将在浏览器端起到作用,在你打开浏览器时决定编码方式 ...
- FreeRTOS 独立看门狗监测任务执行状态
以下转载自安富莱电子: http://forum.armfly.com/forum.php 通过前面的几个章节,我们基本已经完成了 FreeRTOS 所有功能的讲解,本章节为大家介绍一种使用独立看门狗 ...