receipt.func.php 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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. if($data){
  35. $i = 0;
  36. foreach($data AS $_v){
  37. $j = 0;
  38. foreach($_v AS $_cell){
  39. $obj->getActiveSheet(0)->setCellValue($cellName[$j] . ($i+$_row), $_cell);
  40. $j++;
  41. }
  42. $i++;
  43. }
  44. }
  45. //文件名处理
  46. if(!$fileName){
  47. $fileName = uniqid(time(),true);
  48. }
  49. $objWrite = PHPExcel_IOFactory::createWriter($obj, 'Excel2007');
  50. if($isDown){ //网页下载
  51. header('pragma:public');
  52. header("Content-Disposition:attachment;filename=$fileName.xls");
  53. $objWrite->save('php://output');exit;
  54. }
  55. $_fileName = iconv("utf-8", "gb2312", $fileName); //转码
  56. $_savePath = $savePath.$_fileName.'.xlsx';
  57. $objWrite->save($_savePath);
  58. return $savePath.$fileName.'.xlsx';
  59. }
  60. ?>