首页 > php教程 > php手册 > 正文

PhpExcel中文帮助手册|thinkphp适用3.1.2

php中文网
发布: 2016-06-07 11:35:32
原创
1473人浏览过

kevin
我写这些主要是为了以后有个记忆,也为了新手可以作为参考。如有哪里不对,请大家指出我好改正。

第一:你要去PHPExcel官网下载,然后放到网站的Vendor文件夹下面。当然这是为了好管理和导入。你放在其他位置也没有关系。
PhpExcel中文帮助手册|thinkphp适用3.1.2

第二:当然是在你需要的地方写代码。我只写样例,你看懂了就可以灵活的使用。          vendor("PHPExcel.PHPExcel");//如果这里提示类不存在,肯定是你文件夹名字不对。<br>           $objPHPExcel = new \PHPExcel();//这里要注意‘\’ 要有这个。因为版本是3.1.2了。<br>           $objWriter = new \PHPExcel_Writer_Excel5($objPHPExcel);//设置保存版本格式<br><br> //接下来就是写数据到表格里面去<br> $list =你从数据库查出来的的数据<br>  foreach ($list as $key =&gt; $value) {<br>                   $i=$key+1;//表格是从1开始的<br>                   $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('A'.$i,  $value['name']);//这里是设置A1单元格的内容<br>                   $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('B'.$i,  $value['id']);////这里是设置B1单元格的内容<br>                   //以此类推,可以设置C D E F G看你需要了。<br>                   <br> }<br><br> //接下来当然是下载这个表格了,在浏览器输出就好了<br>           header("Pragma: public");<br>           header("Expires: 0");<br>           header("Cache-Control:must-revalidate, post-check=0, pre-check=0");<br>           header("Content-Type:application/force-download");<br>           header("Content-Type:application/vnd.ms-execl");<br>           header("Content-Type:application/octet-stream");<br>           header("Content-Type:application/download");;<br>           header('Content-Disposition:attachment;filename=文件名称.xls');<br>           header("Content-Transfer-Encoding:binary");<br>           $objWriter-&gt;save('文件名称.xls');<br>           $objWriter-&gt;save('php://output');<br><br> 到这里你就已经完成了。如果有哪里不懂可以加我QQ164418960。或者留言<br>             第三 : 上面只是完成了流程而已。但是不可能这样简单而已。我们可以设置很多东西。看自己需要来设置了。设置excel的属性:<br> 创建人<br> $objPHPExcel-&gt;getProperties()-&gt;setCreator("Maarten Balliauw");<br> 最后修改人<br> $objPHPExcel-&gt;getProperties()-&gt;setLastModifiedBy("Maarten Balliauw");<br> 标题<br> $objPHPExcel-&gt;getProperties()-&gt;setTitle("Office 2007 XLSX Test Document");<br> 题目<br> $objPHPExcel-&gt;getProperties()-&gt;setSubject("Office 2007 XLSX Test Document");<br> 描述<br> $objPHPExcel-&gt;getProperties()-&gt;setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");<br> 关键字<br> $objPHPExcel-&gt;getProperties()-&gt;setKeywords("office 2007 openxml php");<br> 种类<br> $objPHPExcel-&gt;getProperties()-&gt;setCategory("Test result file");设置当前的sheet<br> $objPHPExcel-&gt;setActiveSheetIndex(0);<br> 设置sheet的name<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setTitle('Simple');<br> 设置单元格的值<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('A1', 'String');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('A2', 12);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('A3', true);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('C5', '=SUM(C2:C4)');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;setCellValue('B8', '=MIN(B2:C5)');<br> 合并单元格<br> $objPHPExcel-&gt;getActiveSheet()-&gt;mergeCells('A18:E22');<br> 分离单元格<br> $objPHPExcel-&gt;getActiveSheet()-&gt;unmergeCells('A28:B28');<br><br> 保护cell<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getProtection()-&gt;setSheet(true); // Needs to be set to true in order to enable any worksheet protection!<br> $objPHPExcel-&gt;getActiveSheet()-&gt;protectCells('A3:E13', 'PHPExcel');<br> 设置格式<br> // Set cell number formats<br> echo date('H:i:s') . " Set cell number formats\n";<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E4')-&gt;getNumberFormat()-&gt;setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_CURRENCY_EUR_SIMPLE);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;duplicateStyle( $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E4'), 'E5:E13' );<br> 设置宽width<br> // Set column widths<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getColumnDimension('B')-&gt;setAutoSize(true);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getColumnDimension('D')-&gt;setWidth(12);<br> 设置font<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFont()-&gt;setName('Candara');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFont()-&gt;setSize(20);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFont()-&gt;setBold(true);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFont()-&gt;setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFont()-&gt;getColor()-&gt;setARGB(PHPExcel_Style_Color::COLOR_WHITE);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E1')-&gt;getFont()-&gt;getColor()-&gt;setARGB(PHPExcel_Style_Color::COLOR_WHITE);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D13')-&gt;getFont()-&gt;setBold(true);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E13')-&gt;getFont()-&gt;setBold(true);<br> 设置align<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D11')-&gt;getAlignment()-&gt;setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D12')-&gt;getAlignment()-&gt;setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D13')-&gt;getAlignment()-&gt;setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('A18')-&gt;getAlignment()-&gt;setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY);<br> //垂直居中<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('A18')-&gt;getAlignment()-&gt;setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);<br> 设置column的border<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('A4')-&gt;getBorders()-&gt;getTop()-&gt;setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B4')-&gt;getBorders()-&gt;getTop()-&gt;setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('C4')-&gt;getBorders()-&gt;getTop()-&gt;setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D4')-&gt;getBorders()-&gt;getTop()-&gt;setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E4')-&gt;getBorders()-&gt;getTop()-&gt;setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);<br> 设置border的color<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D13')-&gt;getBorders()-&gt;getLeft()-&gt;getColor()-&gt;setARGB('FF993300');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D13')-&gt;getBorders()-&gt;getTop()-&gt;getColor()-&gt;setARGB('FF993300');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('D13')-&gt;getBorders()-&gt;getBottom()-&gt;getColor()-&gt;setARGB('FF993300');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E13')-&gt;getBorders()-&gt;getTop()-&gt;getColor()-&gt;setARGB('FF993300');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E13')-&gt;getBorders()-&gt;getBottom()-&gt;getColor()-&gt;setARGB('FF993300');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('E13')-&gt;getBorders()-&gt;getRight()-&gt;getColor()-&gt;setARGB('FF993300');<br> 设置填充颜色<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('A1')-&gt;getFill()-&gt;setFillType(PHPExcel_Style_Fill::FILL_SOLID);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('A1')-&gt;getFill()-&gt;getStartColor()-&gt;setARGB('FF808080');<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFill()-&gt;setFillType(PHPExcel_Style_Fill::FILL_SOLID);<br> $objPHPExcel-&gt;getActiveSheet()-&gt;getStyle('B1')-&gt;getFill()-&gt;getStartColor()-&gt;setARGB('FF808080');<br> 加图片<br> $objDrawing = new PHPExcel_Worksheet_Drawing();<br> $objDrawing-&gt;setName('Logo');<br> $objDrawing-&gt;setDescription('Logo');<br> $objDrawing-&gt;setPath('./images/officelogo.jpg');<br> $objDrawing-&gt;setHeight(36);<br> $objDrawing-&gt;setWorksheet($objPHPExcel-&gt;getActiveSheet());<br> $objDrawing = new PHPExcel_Worksheet_Drawing();<br> $objDrawing-&gt;setName('Paid');<br> $objDrawing-&gt;setDescription('Paid');<br> $objDrawing-&gt;setPath('./images/paid.png');<br> $objDrawing-&gt;setCoordinates('B15');<br> $objDrawing-&gt;setOffsetX(110);<br> $objDrawing-&gt;setRotation(25);<br> $objDrawing-&gt;getShadow()-&gt;setVisible(true);<br> $objDrawing-&gt;getShadow()-&gt;setDirection(45);<br> $objDrawing-&gt;setWorksheet($objPHPExcel-&gt;getActiveSheet());<br> //处理中文输出问题<br> 需要将字符串转化为UTF-8编码,才能正常输出,否则中文字符将输出为空白,如下处理:<br>  $str  = iconv('gb2312', 'utf-8', $str);<br> 或者你可以写一个函数专门处理中文字符串:<br> function convertUTF8($str)<br> {<br>    if(empty($str)) return '';<br>    return  iconv('gb2312', 'utf-8', $str);<br> }

AD:真正免费,域名+虚机+企业邮箱=0元

WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号