Heim  >  Artikel  >  Backend-Entwicklung  >  PHPExcel最简单的实例教程

PHPExcel最简单的实例教程

WBOY
WBOYOriginal
2016-06-20 12:33:07773Durchsuche

PHPExcel 是相当强大的 MS Office Excel 文档生成类库,当需要输出比较复杂格式数据的时候,PHPExcel 是个不错的选择。不过其使用方法相对来说也就有些繁琐。列举以记之。

PHP代码

  1.     
  2. //设置PHPExcel类库的include path     
  3. set_include_path( '.' . PATH_SEPARATOR .    
  4.                   'D:\Zeal\PHP_LIBS'  . PATH_SEPARATOR .    
  5.                  get_include_path());    
  6.     
  7. /**  
  8.  * 打开对应行的注释。  
  9.  * 如果使用 Excel5 ,输出的内容应该是GBK编码。  
  10.  */     
  11. require_once   'PHPExcel.php' ;    
  12.     
  13. // uncomment     
  14.   
  15. // or     
  16.   
  17.     
  18. // 创建一个处理对象实例     
  19. $objExcel  =  new  PHPExcel();    
  20.     
  21. // 创建文件格式写入对象实例, uncomment     
  22.   
  23. // or     
  24.   
  25. //$objWriter->setOffice2003Compatibility(true);     
  26.     
  27. //*************************************     
  28. //设置文档基本属性     
  29. $objProps  =  $objExcel ->getProperties();    
  30. $objProps ->setCreator( "Zeal Li" );    
  31. $objProps ->setLastModifiedBy( "Zeal Li" );    
  32. $objProps ->setTitle( "Office XLS Test Document" );    
  33. $objProps ->setSubject( "Office XLS Test Document, Demo" );    
  34. $objProps ->setDescription( "Test document, generated by PHPExcel." );    
  35. $objProps ->setKeywords( "office excel PHPExcel" );    
  36. $objProps ->setCategory( "Test" );    
  37.     
  38. //*************************************     
  39. //设置当前的sheet索引,用于后续的内容操作。     
  40. //一般只有在使用多个sheet的时候才需要显示调用。     
  41. //缺省情况下,PHPExcel会自动创建第一个sheet被设置SheetIndex=0     
  42. $objExcel ->setActiveSheetIndex(0);    
  43.     
  44.     
  45. $objActSheet  =  $objExcel ->getActiveSheet();    
  46.     
  47. //设置当前活动sheet的名称     
  48. $objActSheet ->setTitle( '测试Sheet' );    
  49.     
  50. //*************************************     
  51. //设置单元格内容     
  52. //     
  53. //由PHPExcel根据传入内容自动判断单元格内容类型     
  54. $objActSheet ->setCellValue( 'A1' ,  '字符串内容' );   // 字符串内容     
  55. $objActSheet ->setCellValue( 'A2' , 26);             // 数值     
  56. $objActSheet ->setCellValue( 'A3' , true);           // 布尔值     
  57. $objActSheet ->setCellValue( 'A4' ,  '=SUM(A2:A2)' );  // 公式     
  58.     
  59. //显式指定内容类型     
  60. $objActSheet ->setCellValueExplicit( 'A5' ,  '847475847857487584' ,     
  61.                                    PHPExcel_Cell_DataType::TYPE_STRING);    
  62.     
  63. //合并单元格     
  64. $objActSheet ->mergeCells( 'B1:C22' );    
  65.     
  66. //分离单元格     
  67. $objActSheet ->unmergeCells( 'B1:C22' );    
  68.     
  69. //*************************************     
  70. //设置单元格样式     
  71. //     
  72.     
  73. //设置宽度     
  74. $objActSheet ->getColumnDimension( 'B' )->setAutoSize(true);    
  75. $objActSheet ->getColumnDimension( 'A' )->setWidth(30);    
  76.     
  77. $objStyleA5  =  $objActSheet ->getStyle( 'A5' );    
  78.     
  79. //设置单元格内容的数字格式。     
  80. //     
  81. //如果使用了 PHPExcel_Writer_Excel5 来生成内容的话,     
  82.   
  83. //各种自定义格式化方式中,其它类型都可以正常使用,但当setFormatCode     
  84. //为 FORMAT_NUMBER 的时候,实际出来的效果被没有把格式设置为"0"。需要     
  85.   
  86.   
  87. //行代码:      
  88. //if($ifmt === '0') $ifmt = 1;     
  89. //     
  90.   
  91.   
  92. //都按原始内容全部显示出来。     
  93. $objStyleA5     
  94.     ->getNumberFormat()    
  95.     ->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER);    
  96.     
  97. //设置字体     
  98. $objFontA5  =  $objStyleA5 ->getFont();    
  99. $objFontA5 ->setName( 'Courier New' );    
  100. $objFontA5 ->setSize(10);    
  101. $objFontA5 ->setBold(true);    
  102. $objFontA5 ->setUnderline(PHPExcel_Style_Font::UNDERLINE_SINGLE);    
  103. $objFontA5 ->getColor()->setARGB( 'FF999999' );    
  104.     
  105. //设置对齐方式     
  106. $objAlignA5  =  $objStyleA5 ->getAlignment();    
  107. $objAlignA5 ->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_RIGHT);    
  108. $objAlignA5 ->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);    
  109.     
  110. //设置边框     
  111. $objBorderA5  =  $objStyleA5 ->getBorders();    
  112. $objBorderA5 ->getTop()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);    
  113. $objBorderA5 ->getTop()->getColor()->setARGB( 'FFFF0000' );  // color     
  114. $objBorderA5 ->getBottom()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);    
  115. $objBorderA5 ->getLeft()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);    
  116. $objBorderA5 ->getRight()->setBorderStyle(PHPExcel_Style_Border::BORDER_THIN);    
  117.     
  118. //设置填充颜色     
  119. $objFillA5  =  $objStyleA5 ->getFill();    
  120. $objFillA5 ->setFillType(PHPExcel_Style_Fill::FILL_SOLID);    
  121. $objFillA5 ->getStartColor()->setARGB( 'FFEEEEEE' );    
  122.     
  123. //从指定的单元格复制样式信息.     
  124. $objActSheet ->duplicateStyle( $objStyleA5 ,  'B1:C22' );    
  125.     
  126.     
  127. //*************************************     
  128. //添加图片     
  129. $objDrawing  =  new  PHPExcel_Worksheet_Drawing();    
  130. $objDrawing ->setName( 'ZealImg' );    
  131. $objDrawing ->setDescription( 'Image inserted by Zeal' );    
  132. $objDrawing ->setPath( './zeali.net.logo.gif' );    
  133. $objDrawing ->setHeight(36);    
  134. $objDrawing ->setCoordinates( 'C23' );    
  135. $objDrawing ->setOffsetX(10);    
  136. $objDrawing ->setRotation(15);    
  137. $objDrawing ->getShadow()->setVisible(true);    
  138. $objDrawing ->getShadow()->setDirection(36);    
  139. $objDrawing ->setWorksheet( $objActSheet );    
  140.     
  141.     
  142. //添加一个新的worksheet     
  143. $objExcel ->createSheet();    
  144. $objExcel ->getSheet(1)->setTitle( '测试2' );    
  145.     
  146. //保护单元格     
  147. $objExcel ->getSheet(1)->getProtection()->setSheet(true);    
  148. $objExcel ->getSheet(1)->protectCells( 'A1:C22' ,  'PHPExcel' );    
  149.     
  150.     
  151. //*************************************     
  152. //输出内容     
  153. //     
  154. $outputFileName  =  "output.xls" ;    
  155. //到文件     
  156. ////$objWriter->save($outputFileName);     
  157. //or     
  158. //到浏览器     
  159. ////header("Content-Type: application/force-download");     
  160. ////header("Content-Type: application/octet-stream");     
  161. ////header("Content-Type: application/download");     
  162.   
  163. ////header("Content-Transfer-Encoding: binary");     
  164. ////header("Expires: Mon, 26 Jul 1997 05:00:00 GMT");     
  165. ////header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT");     
  166.   
  167. ////header("Pragma: no-cache");     
  168. ////$objWriter->save('php://output');     
  169.     
  170. ?>    

下面是PHPExcel读取Excel文件的例子:

PHP代码

  1. $fileName  =  'excel.xls' ;  
  2. $path  =  'path' ;  
  3. $filePath  =  $path . $fileName ;  
  4. $PHPExcel  =  new  PHPExcel();       
  5. $PHPReader  =  new  PHPExcel_Reader_Excel2007();                 
  6. if (! $PHPReader ->canRead( $filePath )){                          
  7.      $PHPReader  =  new  PHPExcel_Reader_Excel5();    
  8.      if (! $PHPReader ->canRead( $filePath )){                          
  9.          echo   'no Excel' ;  
  10.          return  ;  
  11.     }  
  12. }  
  13. $PHPExcel  =  $PHPReader ->load( $filePath );  
  14. $currentSheet  =  $PHPExcel ->getSheet(0);  
  15. /**取得一共有多少列*/   
  16. $allColumn  =  $currentSheet ->getHighestColumn();     
  17. /**取得一共有多少行*/   
  18. $allRow  =  array ( $currentSheet ->getHighestRow());    
  19.   
  20. for ( $currentRow  = 1; $currentRow
  21.      for ( $currentColumn = 'A' ; $currentColumn
  22.          $address  =  $currentColumn . $currentRow ;  
  23.           
  24.          echo   $currentSheet ->getCell( $address )->getValue(). "\t" ;  
  25.     }  
  26.      echo   "\n" ;  
  27. }  
Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn