国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHPexcel生成復雜的報表表頭類例子

2024-05-04 21:49:51
字體:
來源:轉載
供稿:網友

PHPexcel是一款非常不錯的excel表格操作php插件了,我們通常用它來生成excel文檔或數據轉換并導入到mysql數據庫中,下面介紹的是PHPexcel生成復雜的報表表頭類例子.

以前一直有需求,能把Execl里面的數據導入數據庫,并且把數據庫里面的數據導出到Execl中,代碼如下:

  1. <?php 
  2. require_once dirname(__FILE__) . '/../Classes/PHPExcel/IOFactory.php'
  3.  
  4. class PHPExeclCore extends PHPExcel_IOFactory{ 
  5.    
  6.    
  7.  public static function SummerCreateExecl($Head,$data
  8.  { 
  9.  self::SummerCreateExeclHead($Head,$data,"Excel2007"); 
  10.  } 
  11.    
  12.  public static function SummerReadExecl($dir
  13.  { 
  14.  if(!file_exists($dir)) 
  15.  { 
  16.  echo "Execl Not Exist"
  17.  } 
  18.  else 
  19.  { 
  20.  $PHPExeclObj = self::load($dir); 
  21.    
  22.  $sheetCount = $PHPExeclObj->getSheetCount(); //得到Execl中包含的Sheet工作簿的數量 
  23.    
  24.  for($i=0;$i<$sheetCount;$i++) 
  25.  { 
  26.  $ActiveSheet = $PHPExeclObj->getSheet($i); 
  27.  $highestRow = $ActiveSheet->getHighestRow(); // 取得總列數 
  28.  $allColumn = $ActiveSheet->getHighestColumn(); 
  29.   //開源軟件:Vevb.com 
  30.  //通過嵌套循環來讀取sheet工作簿里面的內容 
  31.  for($Col='A';$Col<$allColumn;$Col++) 
  32.  { 
  33.  for($Row=1;$Row<$highestRow;$Row++) 
  34.  { 
  35.  $Data[$Col][$Row] = $ActiveSheet->getCell($Col.$Row)->getValue(); 
  36.  } 
  37.  } 
  38.  
  39.  } 
  40.  } 
  41.    
  42.  return $Data
  43.  
  44.  } 
  45.    
  46.    
  47.  /* 
  48.  * 將數據寫入到數據表中 
  49.  * $Data Array 表示要插入進Execl數據 
  50.  * $RuleData Array 表示數據格式的規則數組 
  51.  * $i int 表示從第幾行起的插入數據 
  52.  * **/ 
  53.    
  54.  public static function SummerInsertDateToExecl($sheet,$Head,$Data,$n=3,$RuleData=array()) 
  55.  { 
  56.    
  57.  
  58.  $SimpleHead = self::getHead($Head); 
  59.    
  60.  $row = $n
  61.  foreach($Data as $key=>$valueArr
  62.  { 
  63.  $m = 0; 
  64.  foreach($valueArr as $k=>$v
  65.  { 
  66.  $StartCol = PHPExcel_Cell::stringFromColumnIndex($m).$row
  67.  $sheet->getCell($StartCol)->setValue($v); 
  68.  
  69.  $sheet->getStyle($StartCol)->getAlignment()->applyFromArray( 
  70.  array
  71.  'horizontal'=> PHPExcel_Style_Alignment::HORIZONTAL_CENTER, 
  72.  'vertical' => PHPExcel_Style_Alignment::VERTICAL_CENTER, 
  73.  'rotation' => 0, 
  74.  'wrap' => TRUE, 
  75.  ) 
  76.  ); 
  77.    
  78.    
  79.  if(isset($SimpleHead[$k]['col'])) 
  80.  { 
  81.  $m = $m + $SimpleHead[$k]['col']-1; 
  82.  $endCol = PHPExcel_Cell::stringFromColumnIndex($m).$row
  83.  $sheet->mergeCells($StartCol.":".$endCol); 
  84.  } 
  85.    
  86.  $m++; 
  87.    
  88.  $type = false; 
  89.    
  90.  if(isset($SimpleHead[$k]['type'])) 
  91.  { 
  92.  $type = $SimpleHead[$k]['type']; 
  93.  $AllowArray = $SimpleHead[$k]['allowarray']; 
  94.  } 
  95.    
  96.  //設置單元格的數據驗證 
  97.  if($type
  98.  { 
  99.  switch ($type
  100.  { 
  101.  case 'list'
  102.  self::setSelectionRange($sheet$StartCol,$AllowArray); 
  103.  break
  104.  case 'range'
  105.  self::setValueRange($sheet$StartCol,$AllowArray); 
  106.  break
  107.  } 
  108.  } 
  109.  
  110.  } 
  111.  $row ++ ; 
  112.  } 
  113.    
  114.  } 
  115.    
  116.  /* 
  117.  * 生成Execl單元格備注 
  118.  * $sheet 當前的工作簿對象 
  119.  * $Cell 需要設置屬性的單元格 
  120.  * $content 備注內容 
  121.  * */ 
  122.  private static function setComment($sheet,$Cell,$content
  123.  { 
  124.  $sheet->getComment($Cell)->setAuthor('4399om'); 
  125.  $objCommentRichText = $sheet->getComment($Cell)->getText()->createTextRun('4399om:'); 
  126.  $objCommentRichText->getFont()->setBold(true); 
  127.  $sheet->getComment($Cell)->getText()->createTextRun("/r/n"); 
  128.  $sheet->getComment($Cell)->getText()->createTextRun($content); 
  129.  $sheet->getComment($Cell)->setWidth('100pt'); 
  130.  $sheet->getComment($Cell)->setHeight('100pt'); 
  131.  $sheet->getComment($Cell)->setMarginLeft('150pt'); 
  132.  $sheet->getComment($Cell)->getFillColor()->setRGB('EEEEEE'); 
  133.  } 
  134.    
  135.  /* 
  136.  * 現在單元格的有效數據范圍,暫時僅限于數字 
  137.  * $sheet 當前的工作簿對象 
  138.  * $Cell 需要設置屬性的單元格 
  139.  * $ValueRange array 允許輸入數組的訪問 
  140.  */ 
  141.  private static function setValueRange($sheet,$Cell,$ValueRange
  142.  { 
  143.  //設置單元格的的數據類型是數字,并且保留有效位數 
  144.  $sheet->getStyle($Cell)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER_00); 
  145.    
  146.  $ValueRange = explode(",",$ValueRange); 
  147.    
  148.  //開始數值有效訪問設定 
  149.  $objValidation = $sheet->getCell($Cell)->getDataValidation(); 
  150.  $objValidation->setType( PHPExcel_Cell_DataValidation:: TYPE_WHOLE ); 
  151.  $objValidation->setErrorStyle( PHPExcel_Cell_DataValidation:: STYLE_STOP ); 
  152.  $objValidation->setAllowBlank(true); 
  153.  $objValidation->setShowInputMessage( true); //設置顯示提示信息 
  154.  $objValidation->setShowErrorMessage( true); //設置顯示錯誤信息 
  155.  $objValidation->setErrorTitle('輸入錯誤'); //錯誤標題 
  156.  $objValidation->setError('請輸入數據范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //錯誤內容 
  157.  $objValidation->setPromptTitle('允許輸入'); //設置提示標題 
  158.  $objValidation->setPrompt('請輸入數據范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //提示內容 
  159.  $objValidation->setFormula1($ValueRange['0']); //設置最大值 
  160.  $objValidation->setFormula2($ValueRange['1']); //設置最小值 
  161.    
  162.  } 
  163.    
  164.  
  165.  private static function OutinputHeader($objWriter
  166.  { 
  167.  $fileName = str_replace('.php''.xlsx'pathinfo(__FILE__, PATHINFO_BASENAME)); 
  168.  header("Content-Type: application/force-download"); 
  169.  header("Content-Type: application/octet-stream"); 
  170.  header("Content-Type: application/download"); 
  171.  header('Content-Disposition:inline;filename="'.$fileName.'"'); 
  172.  header("Content-Transfer-Encoding: binary"); 
  173.  header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); 
  174.  header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); 
  175.  header("Pragma: no-cache"); 
  176.  $objWriter->save('php://output'); 
  177.  exit
  178.  } 
  179.    
  180.  //數據控制,設置單元格數據在一個可選方位類 
  181.  private static function setSelectionRange($sheet,$Cell,$rangeStr,$Title="數據類型"
  182.  { 
  183.    
  184.  $objValidation = $sheet->getCell($Cell)->getDataValidation(); 
  185.  $objValidation -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST) 
  186.  -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_STOP) 
  187.  -> setAllowBlank(true) 
  188.  -> setShowInputMessage(true) 
  189.  -> setShowErrorMessage(true) 
  190.  -> setShowDropDown(true) 
  191.  -> setErrorTitle('輸入的值有誤'
  192.  -> setError('您輸入的值不在下拉框列表內.'
  193.  -> setPromptTitle('"'.$Title.'"'
  194.  -> setFormula1('"'.$rangeStr.'"'); 
  195.  } 
  196.    
  197.    
  198.    
  199.  /* 
  200.  * 構建表頭 
  201.  * */ 
  202.  public static function RecursionCreateExecl($head,$data
  203.  { 
  204.  
  205.  $PHPExecl = new PHPExcel(); 
  206.    
  207.  $objWriter = self::createWriter($PHPExecl'Excel2007'); 
  208.    
  209.  $PHPExecl->getProperties()->setCreator("4399om"
  210.  ->setLastModifiedBy("Summer"
  211.  ->setTitle("Office 2007 XLSX Test Document"
  212.  ->setSubject("Office 2007 XLSX Test Document"
  213.  ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes."
  214.  ->setKeywords("office 2007 openxml php"
  215.  ->setCategory("Test result file"); 
  216.    
  217.  $PHPExecl->setActiveSheetIndex(0); 
  218.    
  219.  $sheet = $PHPExecl->getActiveSheet(); 
  220.    
  221.  self::HandleHeadToNode($sheet$head,1,0,0); 
  222.    
  223.  self::SummerInsertDateToExecl($sheet,$head,$data,4); 
  224.  
  225.  self::OutinputHeader($objWriter); 
  226.  } 
  227.    
  228.  private static function HandleHeadToNode($sheet,$Head,$beginRow,$col,$StartCol
  229.  { 
  230.  
  231.    
  232.  foreach($Head as $key=>$cells
  233.  { 
  234.  $row = $beginRow//表示行 
  235.    
  236.  $beginCol = PHPExcel_Cell::stringFromColumnIndex($col).$row
  237.    
  238.  $sheet->getCell($beginCol)->setValue($cells['value']); 
  239.    
  240.  //設置表格樣式 
  241.  $sheet->getStyle($beginCol)->getAlignment()->applyFromArray( 
  242.  array
  243.  'horizontal'=> PHPExcel_Style_Alignment::HORIZONTAL_CENTER, 
  244.  'vertical' => PHPExcel_Style_Alignment::VERTICAL_CENTER, 
  245.  'rotation' => 0, 
  246.  'wrap' => TRUE, 
  247.  ) 
  248.  ); 
  249.    
  250.  $sheet->getStyle($beginCol)->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_DARKGREEN); 
  251.    
  252.  //設置單元格的寬度 
  253.  if(isset($cells['width'])) 
  254.  { 
  255.  $Cell = $sheet->getColumnDimension(PHPExcel_Cell::stringFromColumnIndex($col)); 
  256.  $Cell->setWidth($cells['width']); 
  257.  } 
  258.    
  259.  //哥元素打上標記 
  260.  if(isset($cells['Content'])) 
  261.  { 
  262.  self::setComment($sheet$beginCol$cells['Content']); 
  263.  } 
  264.    
  265.  $merge = false; //合并單元格 
  266.  if(isset($cells['col'])) 
  267.  { 
  268.  $col += $cells['col']-1; 
  269.  $merge = true; 
  270.  } 
  271.    
  272.  if(isset($cells['row'])) 
  273.  { 
  274.  $row += $cells['row']-1; 
  275.  $merge = true; 
  276.  } 
  277.    
  278.  if($merge
  279.  { 
  280.  $endCol = PHPExcel_Cell::stringFromColumnIndex($col).$row
  281.  $sheet->mergeCells($beginCol.":".$endCol); 
  282.  } 
  283.    
  284.  $row ++; 
  285.  $col ++; 
  286.    
  287.  //表示有存在孩子節點 
  288.  if(isset($cells['children']) && is_array($cells['children'])){ 
  289.  $cols = $StartCol
  290.  if(!self::IsExistChildren($cells['children'])) 
  291.  { 
  292.  $cols = $col-2; 
  293.  $StartCol = $col
  294.  } 
  295.  
  296.  self::HandleHeadToNode($sheet,$cells['children'],$row,$cols,$StartCol); 
  297.  }else
  298.  $StartCol = $col
  299.  } 
  300.    
  301.  
  302.  } 
  303.    
  304.  } 
  305.  
  306.  //判斷自己的孩子節點中是否存在孫子節點 
  307.  private static function IsExistChildren($Data
  308.  { 
  309.  foreach($Data as $key=>$value
  310.  { 
  311.  if(isset($value['children']) && is_array($value['children'])) 
  312.  { 
  313.  return true; 
  314.  } 
  315.  } 
  316.  return false; 
  317.  } 
  318.    
  319.    
  320.  //獲取底層數據 
  321.  private static function getHead($Head,&$Node=array()) 
  322.  { 
  323.  foreach($Head as $key=>$value
  324.  { 
  325.  if(isset($value['children']) && is_array($value['children'])) 
  326.  { 
  327.  self::getHead($value['children'],$Node); 
  328.  } 
  329.  else 
  330.  { 
  331.  $Node[] = $value
  332.  } 
  333.  } 
  334.    
  335.  return $Node
  336.  } 
  337.    
  338.  
  339.  
  340.  
  341.  
  342. $Head = array
  343.  array('value'=>'姓名','col'=>2,'row'=>2,'width'=>20,'type'=>'list','allowarray'=>'PHP開發工程師,PHP開發'), 
  344.  array('value'=>'第一天','col'=>2,'row'=>1,'width'=>20,'Content'=>'2014-12-29號'
  345.  'children'=> 
  346.  array
  347.  array('value'=>'上午','col'=>1,'width'=>20,'type'=>'range','allowarray'=>'10,100'), 
  348.  array('value'=>'下午','width'=>20), 
  349.  ), 
  350.    
  351.  ), 
  352.  array('value'=>'第二天','col'=>2,'row'=>1,'width'=>20, 
  353.  'children'=> 
  354.  array
  355.  array('value'=>'上午','width'=>20), 
  356.  array('value'=>'下午','width'=>20), 
  357.  ), 
  358.  ), 
  359. ); 
  360.  
  361.  
  362. $data = array
  363.  array('PHP開發工程師','12','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'), 
  364.  array('PHP開發工程師','25','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'), 
  365.  array('PHP開發工程師','50','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'), 
  366.  array('PHP開發工程師','99','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'), 
  367.  array('PHP開發工程師','10','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'), 
  368.  ); 
  369.  
  370. $Node = PHPExeclCore::RecursionCreateExecl($Head,$data); 
  371. ?> 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 临澧县| 伊宁县| 长海县| 大宁县| 禹城市| 民乐县| 临颍县| 中阳县| 鹤山市| 泰兴市| 平定县| 巩留县| 合阳县| 威宁| 普兰店市| 鞍山市| 图片| 周至县| 张家川| 年辖:市辖区| 壶关县| 麻栗坡县| 错那县| 江山市| 共和县| 衡南县| 云龙县| 闵行区| 漳浦县| 什邡市| 乐清市| 无锡市| 南丰县| 望城县| 枝江市| 木兰县| 康马县| 大石桥市| 重庆市| 明星| 文登市|