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

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

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

第二:当然是在你需要的地方写代码。我只写样例,你看懂了就可以灵活的使用。

 

 
 
  1. vendor("PHPExcel.PHPExcel");//如果这里提示类不存在,肯定是你文件夹名字不对。
  2. $objPHPExcel = new \PHPExcel();//这里要注意‘\’ 要有这个。因为版本是3.1.2了。
  3. $objWriter = new \PHPExcel_Writer_Excel5($objPHPExcel);//设置保存版本格式
  4. //接下来就是写数据到表格里面去
  5. $list =你从数据库查出来的的数据
  6. foreach ($list as $key => $value) {
  7. $i=$key+1;//表格是从1开始的
  8. $objPHPExcel->getActiveSheet()->setCellValue('A'.$i, $value['name']);//这里是设置A1单元格的内容
  9. $objPHPExcel->getActiveSheet()->setCellValue('B'.$i, $value['id']);这里是设置B1单元格的内容
  10. //以此类推,可以设置C D E F G看你需要了。
  11. }
  12. //接下来当然是下载这个表格了,在浏览器输出就好了
  13. header("Pragma: public");
  14. header("Expires: 0");
  15. header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
  16. header("Content-Type:application/force-download");
  17. header("Content-Type:application/vnd.ms-execl");
  18. header("Content-Type:application/octet-stream");
  19. header("Content-Type:application/download");;
  20. header('Content-Disposition:attachment;filename=文件名称.xls');
  21. header("Content-Transfer-Encoding:binary");
  22. $objWriter->save('文件名称.xls');
  23. $objWriter->save('php://output');
  24. 到这里你就已经完成了。如果有哪里不懂可以加我QQ164418960。或者留言
  25.  

第三 : 上面只是完成了流程而已。但是不可能这样简单而已。我们可以设置很多东西。看自己需要来设置了。

 

 
 
  1. 设置excel的属性:
  2. 创建人
  3. $objPHPExcel->getProperties()->setCreator("Maarten Balliauw");
  4. 最后修改人
  5. $objPHPExcel->getProperties()->setLastModifiedBy("Maarten Balliauw");
  6. 标题
  7. $objPHPExcel->getProperties()->setTitle("Office 2007 XLSX Test Document");
  8. 题目
  9. $objPHPExcel->getProperties()->setSubject("Office 2007 XLSX Test Document");
  10. 描述
  11. $objPHPExcel->getProperties()->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.");
  12. 关键字
  13. $objPHPExcel->getProperties()->setKeywords("office 2007 openxml php");
  14. 种类
  15. $objPHPExcel->getProperties()->setCategory("Test result file");
  16. 设置当前的sheet
  17. $objPHPExcel->setActiveSheetIndex(0);
  18. 设置sheetname
  19. $objPHPExcel->getActiveSheet()->setTitle('Simple');
  20. 设置单元格的值
  21. $objPHPExcel->getActiveSheet()->setCellValue('A1', 'String');
  22. $objPHPExcel->getActiveSheet()->setCellValue('A2', 12);
  23. $objPHPExcel->getActiveSheet()->setCellValue('A3', true);
  24. $objPHPExcel->getActiveSheet()->setCellValue('C5', '=SUM(C2:C4)');
  25. $objPHPExcel->getActiveSheet()->setCellValue('B8', '=MIN(B2:C5)');
  26. 合并单元格
  27. $objPHPExcel->getActiveSheet()->mergeCells('A18:E22');
  28. 分离单元格
  29. $objPHPExcel->getActiveSheet()->unmergeCells('A28:B28');
  30. 保护cell
  31. $objPHPExcel->getActiveSheet()->getProtection()->setSheet(true); // Needs to be set to true in order to enable any worksheet protection!
  32. $objPHPExcel->getActiveSheet()->protectCells('A3:E13', 'PHPExcel');
  33. 设置格式
  34. // Set cell number formats
  35. echo date('H:i:s') . " Set cell number formats\n";
  36. $objPHPExcel->getActiveSheet()->getStyle('E4')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_CURRENCY_EUR_SIMPLE);
  37. $objPHPExcel->getActiveSheet()->duplicateStyle( $objPHPExcel->getActiveSheet()->getStyle('E4'), 'E5:E13' );
  38. 设置宽width
  39. // Set column widths
  40. $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setAutoSize(true);
  41. $objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(12);
  42. 设置font
  43. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setName('Candara');
  44. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setSize(20);
  45. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setBold(true);
  46. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);
  47. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
  48. $objPHPExcel->getActiveSheet()->getStyle('E1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
  49. $objPHPExcel->getActiveSheet()->getStyle('D13')->getFont()->setBold(true);
  50. $objPHPExcel->getActiveSheet()->getStyle('E13')->getFont()->setBold(true);
  51. 设置align
  52. $objPHPExcel->getActiveSheet()->getStyle('D11')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
  53. $objPHPExcel->getActiveSheet()->getStyle('D12')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
  54. $objPHPExcel->getActiveSheet()->getStyle('D13')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
  55. $objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY);
  56. //垂直居中
  57. $objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
  58. 设置columnborder
  59. $objPHPExcel->getActiveSheet()->getStyle('A4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
  60. $objPHPExcel->getActiveSheet()->getStyle('B4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
  61. $objPHPExcel->getActiveSheet()->getStyle('C4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
  62. $objPHPExcel->getActiveSheet()->getStyle('D4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
  63. $objPHPExcel->getActiveSheet()->getStyle('E4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
  64. 设置bordercolor
  65. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getLeft()->getColor()->setARGB('FF993300');
  66. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
  67. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
  68. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
  69. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
  70. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getRight()->getColor()->setARGB('FF993300');
  71. 设置填充颜色
  72. $objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  73. $objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->getStartColor()->setARGB('FF808080');
  74. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
  75. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->getStartColor()->setARGB('FF808080');
  76. 加图片
  77. $objDrawing = new PHPExcel_Worksheet_Drawing();
  78. $objDrawing->setName('Logo');
  79. $objDrawing->setDescription('Logo');
  80. $objDrawing->setPath('./images/officelogo.jpg');
  81. $objDrawing->setHeight(36);
  82. $objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
  83. $objDrawing = new PHPExcel_Worksheet_Drawing();
  84. $objDrawing->setName('Paid');
  85. $objDrawing->setDescription('Paid');
  86. $objDrawing->setPath('./images/paid.png');
  87. $objDrawing->setCoordinates('B15');
  88. $objDrawing->setOffsetX(110);
  89. $objDrawing->setRotation(25);
  90. $objDrawing->getShadow()->setVisible(true);
  91. $objDrawing->getShadow()->setDirection(45);
  92. $objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
  93. //处理中文输出问题
  94. 需要将字符串转化为UTF-8编码,才能正常输出,否则中文字符将输出为空白,如下处理:
  95. $str = iconv('gb2312', 'utf-8', $str);
  96. 或者你可以写一个函数专门处理中文字符串:
  97. function convertUTF8($str)
  98. {
  99. if(empty($str)) return '';
  100. return iconv('gb2312', 'utf-8', $str);
  101. }
  102.  
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值