ThinkPHP中PHPExcel的使用

固然是在你須要的地方寫代碼。我只寫樣例,你看懂了就能夠靈活的使用。php

  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. //接下來固然是下載這個表格了,在瀏覽器輸出就行了
  14.           header("Pragma: public");
  15.           header("Expires: 0");
  16.           header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
  17.           header("Content-Type:application/force-download");
  18.           header("Content-Type:application/vnd.ms-execl");
  19.           header("Content-Type:application/octet-stream");
  20.           header("Content-Type:application/download");;
  21.           header('Content-Disposition:attachment;filename=文件名稱.xls');
  22.           header("Content-Transfer-Encoding:binary");
  23.           $objWriter->save('文件名稱.xls');
  24.           $objWriter->save('php://output');

  25. 到這裏你就已經完成了。若是有哪裏不懂能夠加我QQ164418960。或者留言
  26.             
複製代碼

第三 : 上面只是完成了流程而已。可是不可能這樣簡單而已。咱們能夠設置不少東西。看本身須要來設置了。數據庫

  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");
複製代碼
    1. 設置當前的sheet
    2. $objPHPExcel->setActiveSheetIndex(0);
    3. 設置sheetname
    4. $objPHPExcel->getActiveSheet()->setTitle('Simple');
    5. 設置單元格的值
    6. $objPHPExcel->getActiveSheet()->setCellValue('A1', 'String');
    7. $objPHPExcel->getActiveSheet()->setCellValue('A2', 12);
    8. $objPHPExcel->getActiveSheet()->setCellValue('A3', true);
    9. $objPHPExcel->getActiveSheet()->setCellValue('C5', '=SUM(C2:C4)');
    10. $objPHPExcel->getActiveSheet()->setCellValue('B8', '=MIN(B2:C5)');
    11. 合併單元格
    12. $objPHPExcel->getActiveSheet()->mergeCells('A18:E22');
    13. 分離單元格
    14. $objPHPExcel->getActiveSheet()->unmergeCells('A28:B28');

    15. 保護cell
    16. $objPHPExcel->getActiveSheet()->getProtection()->setSheet(true); // Needs to be set to true in order to enable any worksheet protection!
    17. $objPHPExcel->getActiveSheet()->protectCells('A3:E13', 'PHPExcel');
    18. 設置格式
    19. // Set cell number formats
    20. echo date('H:i:s') . " Set cell number formats\n";
    21. $objPHPExcel->getActiveSheet()->getStyle('E4')->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_CURRENCY_EUR_SIMPLE);
    22. $objPHPExcel->getActiveSheet()->duplicateStyle( $objPHPExcel->getActiveSheet()->getStyle('E4'), 'E5:E13' );
    23. 設置寬width
    24. // Set column widths
    25. $objPHPExcel->getActiveSheet()->getColumnDimension('B')->setAutoSize(true);
    26. $objPHPExcel->getActiveSheet()->getColumnDimension('D')->setWidth(12);
    27. 設置font
    28. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setName('Candara');
    29. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setSize(20);
    30. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setBold(true);
    31. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);
    32. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
    33. $objPHPExcel->getActiveSheet()->getStyle('E1')->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_WHITE);
    34. $objPHPExcel->getActiveSheet()->getStyle('D13')->getFont()->setBold(true);
    35. $objPHPExcel->getActiveSheet()->getStyle('E13')->getFont()->setBold(true);
    36. 設置align
    37. $objPHPExcel->getActiveSheet()->getStyle('D11')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
    38. $objPHPExcel->getActiveSheet()->getStyle('D12')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
    39. $objPHPExcel->getActiveSheet()->getStyle('D13')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);
    40. $objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_JUSTIFY);
    41. //垂直居中
    42. $objPHPExcel->getActiveSheet()->getStyle('A18')->getAlignment()->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
    43. 設置columnborder
    44. $objPHPExcel->getActiveSheet()->getStyle('A4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
    45. $objPHPExcel->getActiveSheet()->getStyle('B4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
    46. $objPHPExcel->getActiveSheet()->getStyle('C4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
    47. $objPHPExcel->getActiveSheet()->getStyle('D4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
    48. $objPHPExcel->getActiveSheet()->getStyle('E4')->getBorders()->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);
    49. 設置bordercolor
    50. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getLeft()->getColor()->setARGB('FF993300');
    51. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
    52. $objPHPExcel->getActiveSheet()->getStyle('D13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
    53. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getTop()->getColor()->setARGB('FF993300');
    54. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getBottom()->getColor()->setARGB('FF993300');
    55. $objPHPExcel->getActiveSheet()->getStyle('E13')->getBorders()->getRight()->getColor()->setARGB('FF993300');
    56. 設置填充顏色
    57. $objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
    58. $objPHPExcel->getActiveSheet()->getStyle('A1')->getFill()->getStartColor()->setARGB('FF808080');
    59. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->setFillType(PHPExcel_Style_Fill::FILL_SOLID);
    60. $objPHPExcel->getActiveSheet()->getStyle('B1')->getFill()->getStartColor()->setARGB('FF808080');
    61. 加圖片
    62. $objDrawing = new PHPExcel_Worksheet_Drawing();
    63. $objDrawing->setName('Logo');
    64. $objDrawing->setDescription('Logo');
    65. $objDrawing->setPath('./images/officelogo.jpg');
    66. $objDrawing->setHeight(36);
    67. $objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
    68. $objDrawing = new PHPExcel_Worksheet_Drawing();
    69. $objDrawing->setName('Paid');
    70. $objDrawing->setDescription('Paid');
    71. $objDrawing->setPath('./images/paid.png');
    72. $objDrawing->setCoordinates('B15');
    73. $objDrawing->setOffsetX(110);
    74. $objDrawing->setRotation(25);
    75. $objDrawing->getShadow()->setVisible(true);
    76. $objDrawing->getShadow()->setDirection(45);
    77. $objDrawing->setWorksheet($objPHPExcel->getActiveSheet());
    78. //處理中文輸出問題
    79. 須要將字符串轉化爲UTF-8編碼,才能正常輸出,不然中文字符將輸出爲空白,以下處理:
    80.  $str  = iconv('gb2312', 'utf-8', $str);
    81. 或者你能夠寫一個函數專門處理中文字符串:
    82. function convertUTF8($str)
    83. {
    84.    if(empty($str)) return '';
    85.    return  iconv('gb2312', 'utf-8', $str);
    86. }
相關文章
相關標籤/搜索