receipt.func.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. /**
  3. * 数据导出
  4. * @param array $title 标题行名称
  5. * @param array $data 导出数据
  6. * @param string $fileName 文件名
  7. * @param string $savePath 保存路径
  8. * @param $type 是否下载 false--保存 true--下载
  9. * @return string 返回文件全路径
  10. * @throws PHPExcel_Exception
  11. * @throws PHPExcel_Reader_Exception
  12. * @exportExcel(array('姓名','年龄'), array(array('a',21),array('b',23)), '档案', './', true);
  13. */
  14. function exportExcel($title=array(), $data=array(), $fileName='', $savePath='./', $isDown=false){
  15. Doo::loadClass ( 'PHPExcel1.7.9/PHPExcel' );
  16. $obj = new PHPExcel();
  17. //横向单元格标识
  18. $cellName = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');
  19. $obj->getActiveSheet(0)->setTitle('sheet名称'); //设置sheet名称
  20. $_row = 0; //设置纵向单元格标识
  21. if($title){
  22. $_cnt = count($title);
  23. //$obj->getActiveSheet(0)->mergeCells('A'.$_row.':'.$cellName[$_cnt-1].$_row); //合并单元格
  24. //$obj->setActiveSheetIndex(0)->setCellValue('A'.$_row, '数据导出:'.date('Y-m-d H:i:s')); //设置合并后的单元格内容
  25. $_row++;
  26. $i = 0;
  27. foreach($title AS $v){ //设置列标题
  28. $obj->setActiveSheetIndex(0)->setCellValue($cellName[$i].$_row, $v);
  29. $i++;
  30. }
  31. $_row++;
  32. }
  33. ;
  34. //html_entity_decode("&iuml;&raquo;&iquest;".$value['order_id']);
  35. //填写数据
  36. if($data){
  37. $i = 0;
  38. foreach($data AS $_v){
  39. $j = 0;
  40. foreach($_v AS $_cell){
  41. $obj->getActiveSheet(0)->setCellValueExplicit($cellName[$j] . ($i+$_row), $_cell,PHPExcel_Cell_DataType::TYPE_STRING);
  42. $j++;
  43. }
  44. $i++;
  45. }
  46. }
  47. //文件名处理
  48. if(!$fileName){
  49. $fileName = uniqid(time(),true);
  50. }
  51. $objWrite = PHPExcel_IOFactory::createWriter($obj, 'Excel2007');
  52. if($isDown){ //网页下载
  53. header('pragma:public');
  54. header("Content-Disposition:attachment;filename=$fileName.xls");
  55. header('Content-Type:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
  56. $objWrite->save('php://output');exit;
  57. }
  58. $_fileName = iconv("utf-8", "gb2312", $fileName); //转码
  59. $_savePath = $savePath.$_fileName.'.xlsx';
  60. $objWrite->save($_savePath);
  61. return $savePath.$fileName.'.xlsx';
  62. }
  63. ?>