您的位置 首页 php

php操作excel,附完整代码

准备工作:

1.下载phpexcel1.7.6类包;

2.解压至TP框架的ThinkPHP\Vendor目录下,改类包文件夹名为PHPExcel176,目录结构如下图;

编写代码(以一个订单汇总数据为例):

1. 创建数据库及表;

2. 创建tp项目,配置项目的数据库连接,这些基本的就不说了;

3. 在项目的Lib\Action下创建一个新的类文件ExportStatisticsAction.class.php,然后在 index方法中实现excel导出;

4. 导出方法的步骤:

①查询数据

②导入phpexcel类库

③创建excel对象并设置excel对象的属性

④设置excel的行列样式(字体、高宽、颜色、边框、合并等)

⑤绘制报表表头

⑥将查询数据写入excel

⑦设置excel的 sheet 的名称

⑧设置excel报表打开后初始的sheet

⑨设置输出的excel的头参数及文件名

⑩调用创建excel的方法生成excel文件

代码如下:( 可根据需求进行循环操作 )

[php] view plain copy

  1. <?php

  2. /**

  3. * Created by lonm.shi.

  4. * Date: 2012-02-09

  5. * Time: 下午4:54

  6. * To change this template use File | Settings | File Templates.

  7. */

  8. class ExportStatisticsAction extends Action {

  9. public function index(){

  10. $model= D(“OrdersView”);

  11. $OrdersData= $model->select(); //查询数据得到$OrdersData二维数组

  12. vendor(“PHPExcel176.PHPExcel”);

  13. // Create new PHPExcel object

  14. $objPHPExcel = new PHPExcel();

  15. // Set properties

  16. $objPHPExcel->getProperties()->setCreator(“ctos”)

  17. ->setLastModifiedBy(“ctos”)

  18. ->setTitle(“Office 2007 xlsx Test Document”)

  19. ->setSubject(“Office 2007 XLSX Test Document”)

  20. ->setDescription(“Test document for Office 2007 XLSX, generated using PHP classes.”)

  21. ->setKeywords(“office 2007 openxml php”)

  22. ->setCategory(“Test result file”);

  23. //set width

  24. $objPHPExcel->getActiveSheet()->getColumnDimension(‘A’)->setWidth(8);

  25. $objPHPExcel->getActiveSheet()->getColumnDimension(‘B’)->setWidth(10);

  26. $objPHPExcel->getActiveSheet()->getColumnDimension(‘C’)->setWidth(25);

  27. $objPHPExcel->getActiveSheet()->getColumnDimension(‘D’)->setWidth(12);

  28. $objPHPExcel->getActiveSheet()->getColumnDimension(‘E’)->setWidth(50);

  29. $objPHPExcel->getActiveSheet()->getColumnDimension(‘F’)->setWidth(10);

  30. $objPHPExcel->getActiveSheet()->getColumnDimension(‘G’)->setWidth(12);

  31. $objPHPExcel->getActiveSheet()->getColumnDimension(‘H’)->setWidth(12);

  32. $objPHPExcel->getActiveSheet()->getColumnDimension(‘I’)->setWidth(12);

  33. $objPHPExcel->getActiveSheet()->getColumnDimension(‘J’)->setWidth(30);

  34. //设置行高度

  35. $objPHPExcel->getActiveSheet()->getRowDimension(‘1’)->setRowHeight(22);

  36. $objPHPExcel->getActiveSheet()->getRowDimension(‘2’)->setRowHeight(20);

  37. //set font size bold

  38. $objPHPExcel->getActiveSheet()->getDefaultStyle()->getFont()->setSize(10);

  39. $objPHPExcel->getActiveSheet()->getStyle(‘A2:J2’)->getFont()->setBold(true);

  40. $objPHPExcel->getActiveSheet()->getStyle(‘A2:J2’)->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);

  41. $objPHPExcel->getActiveSheet()->getStyle(‘A2:J2’)->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);

  42. //设置水平居中

  43. $objPHPExcel->getActiveSheet()->getStyle(‘A1’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_LEFT);

  44. $objPHPExcel->getActiveSheet()->getStyle(‘A’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  45. $objPHPExcel->getActiveSheet()->getStyle(‘B’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  46. $objPHPExcel->getActiveSheet()->getStyle(‘D’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  47. $objPHPExcel->getActiveSheet()->getStyle(‘F’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  48. $objPHPExcel->getActiveSheet()->getStyle(‘G’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  49. $objPHPExcel->getActiveSheet()->getStyle(‘H’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  50. $objPHPExcel->getActiveSheet()->getStyle(‘I’)->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);

  51. //合并cell

  52. $objPHPExcel->getActiveSheet()->mergeCells(‘A1:J1’);

  53. // set table header content

  54. $objPHPExcel->setActiveSheetIndex(0)

  55. ->setCellValue(‘A1’, ‘订单数据汇总 时间:’.date(‘Y-m-d H:i:s’))

  56. ->setCellValue(‘A2’, ‘订单ID’)

  57. ->setCellValue(‘B2’, ‘下单人’)

  58. ->setCellValue(‘C2’, ‘客户名称’)

  59. ->setCellValue(‘D2’, ‘下单时间’)

  60. ->setCellValue(‘E2’, ‘需求机型’)

  61. ->setCellValue(‘F2’, ‘需求数量’)

  62. ->setCellValue(‘G2’, ‘需求交期’)

  63. ->setCellValue(‘H2’, ‘确认BOM料号’)

  64. ->setCellValue(‘I2’, ‘ PMC 确认交期’)

  65. ->setCellValue(‘J2’, ‘PMC交货备注’);

  66. // Miscellaneous glyphs, UTF-8

  67. for($i=0;$i<count($OrdersData)-1;$i++){

  68. $objPHPExcel->getActiveSheet(0)->setCellValue(‘A’.($i+3), $OrdersData[$i][‘id’]);

  69. $objPHPExcel->getActiveSheet(0)->setCellValue(‘B’.($i+3), $OrdersData[$i][‘realname’]);

  70. $objPHPExcel->getActiveSheet(0)->setCellValue(‘C’.($i+3), $OrdersData[$i][‘customer_name’]);

  71. $objPHPExcel->getActiveSheet(0)->setCellValue(‘D’.($i+3), toDate($OrdersData[$i][‘create_time’])); //这里调用了common.php的时间戳转换函数

  72. $objPHPExcel->getActiveSheet(0)->setCellValue(‘E’.($i+3), $OrdersData[$i][‘require_product’]);

  73. $objPHPExcel->getActiveSheet(0)->setCellValue(‘F’.($i+3), $OrdersData[$i][‘require_count’]);

  74. $objPHPExcel->getActiveSheet(0)->setCellValue(‘G’.($i+3), $OrdersData[$i][‘require_time’]);

  75. $objPHPExcel->getActiveSheet(0)->setCellValue(‘H’.($i+3), $OrdersData[$i][‘product_bom_encoding’]);

  76. $objPHPExcel->getActiveSheet(0)->setCellValue(‘I’.($i+3), $OrdersData[$i][‘delivery_time’]);

  77. $objPHPExcel->getActiveSheet(0)->setCellValue(‘J’.($i+3), $OrdersData[$i][‘delivery_memo’]);

  78. $objPHPExcel->getActiveSheet()->getStyle(‘A’.($i+3).’:J’.($i+3))->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);

  79. $objPHPExcel->getActiveSheet()->getStyle(‘A’.($i+3).’:J’.($i+3))->getBorders()->getAllBorders()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);

  80. $objPHPExcel->getActiveSheet()->getRowDimension($i+3)->setRowHeight(16);

  81. }

  82. // sheet命名

  83. $objPHPExcel->getActiveSheet()->setTitle(‘订单汇总表’);

  84. // Set active sheet index to the first sheet, so Excel opens this as the first sheet

  85. $objPHPExcel->setActiveSheetIndex(0);

  86. // excel头参数

  87. header(‘Content-Type: application/vnd.ms-excel’);

  88. header(‘Content-Disposition: attachment;filename=”订单汇总表(‘.date(‘Ymd-His’).’).xls”‘); //日期为文件名后缀

  89. header(‘Cache-Control: max-age=0’);

  90. $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, ‘Excel5’); //excel5为xls格式, excel2007 为xlsx格式

  91. $objWriter->save(‘php://output’);

  92. }

  93. }

5.调用导出方法直接 http://项目/index.php/ExportStatistics/index,项目中调用直接__APP__/ExportStatistics/index,生成的报表是下载方式来保存。phpexcel1.7.6没有发现什么编码问题,速度也很快,注意导出的方法中不能有任何页面输出信息或调试信息,否则导出的excel会提示格式不对。效果如下:

导出报表

文章来源:智云一二三科技

文章标题:php操作excel,附完整代码

文章地址:https://www.zhihuclub.com/79983.shtml

关于作者: 智云科技

热门文章

网站地图