php操作excel,附完整代码

2022-10-11 20:57:59 270 0
魁首哥

准备工作:

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. /**

  2. * Created by lonm.shi.

  3. * Date: 2012-02-09

  4. * Time: 下午4:54

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

  6. */

  7. class ExportStatisticsAction extends Action {

  8. public function index(){

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

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

  11. vendor(“PHPExcel176.PHPExcel”);

  12. // Create new PHPExcel object

  13. $objPHPExcel = new PHPExcel();

  14. // Set properties

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

  16. ->setLastModifiedBy(“ctos”)

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

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

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

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

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

  22. //set width

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

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

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

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

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

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

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

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

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

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

  33. //设置行高度

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

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

  36. //set font size bold

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

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

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

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

  41. //设置水平居中

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

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

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

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

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

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

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

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

  50. //合并cell

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

  52. // set table header content

  53. $objPHPExcel->setActiveSheetIndex(0)

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

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

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

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

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

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

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

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

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

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

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

  65. // Miscellaneous glyphs, UTF-8

  66. for($i=0;$i

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

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

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

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

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

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

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

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

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

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

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

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

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

  80. }

  81. // sheet命名

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

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

  84. $objPHPExcel->setActiveSheetIndex(0);

  85. // excel头参数

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

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

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

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

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

  91. }

  92. }

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

导出报表

收藏
分享
海报
0 条评论
270
上一篇:猪肉涨到什么时候就不涨了(猪肉价格什么时候可以恢复正常) 下一篇:淘宝每个月都有满减吗(淘宝2022年6月满减活动有哪些)

本站已关闭游客评论,请登录或者注册后再评论吧~

忘记密码?

图形验证码