基于PHPexecl類(lèi)生成復(fù)雜的報(bào)表表頭示例
本文實(shí)例講述了基于PHPexecl類(lèi)生成復(fù)雜的報(bào)表表頭。分享給大家供大家參考,具體如下:
以前一直有需求,能把Execl里面的數(shù)據(jù)導(dǎo)入數(shù)據(jù)庫(kù),并且把數(shù)據(jù)庫(kù)里面的數(shù)據(jù)導(dǎo)出到Execl中。
require_once dirname(__FILE__) . '/../Classes/PHPExcel/IOFactory.php'; class PHPExeclCore extends PHPExcel_IOFactory{ public static function SummerCreateExecl($Head,$data) { self::SummerCreateExeclHead($Head,$data,"Excel2007"); } public static function SummerReadExecl($dir) { if(!file_exists($dir)) { echo "Execl Not Exist"; } else { $PHPExeclObj = self::load($dir); $sheetCount = $PHPExeclObj->getSheetCount(); //得到Execl中包含的Sheet工作簿的數(shù)量 for($i=0;$i<$sheetCount;$i++) { $ActiveSheet = $PHPExeclObj->getSheet($i); $highestRow = $ActiveSheet->getHighestRow(); // 取得總列數(shù) $allColumn = $ActiveSheet->getHighestColumn(); //通過(guò)嵌套循環(huán)來(lái)讀取sheet工作簿里面的內(nèi)容 for($Col='A';$Col<$allColumn;$Col++) { for($Row=1;$Row<$highestRow;$Row++) { $Data[$Col][$Row] = $ActiveSheet->getCell($Col.$Row)->getValue(); } } } } return $Data; } /* * 將數(shù)據(jù)寫(xiě)入到數(shù)據(jù)表中 * $Data Array 表示要插入進(jìn)Execl數(shù)據(jù) * $RuleData Array 表示數(shù)據(jù)格式的規(guī)則數(shù)組 * $i int 表示從第幾行起的插入數(shù)據(jù) * **/ public static function SummerInsertDateToExecl($sheet,$Head,$Data,$n=3,$RuleData=array()) { $SimpleHead = self::getHead($Head); $row = $n; foreach($Data as $key=>$valueArr) { $m = 0; foreach($valueArr as $k=>$v) { $StartCol = PHPExcel_Cell::stringFromColumnIndex($m).$row; $sheet->getCell($StartCol)->setValue($v); $sheet->getStyle($StartCol)->getAlignment()->applyFromArray( array( 'horizontal'=> PHPExcel_Style_Alignment::HORIZONTAL_CENTER, 'vertical' => PHPExcel_Style_Alignment::VERTICAL_CENTER, 'rotation' => 0, 'wrap' => TRUE, ) ); if(isset($SimpleHead[$k]['col'])) { $m = $m + $SimpleHead[$k]['col']-1; $endCol = PHPExcel_Cell::stringFromColumnIndex($m).$row; $sheet->mergeCells($StartCol.":".$endCol); } $m++; $type = false; if(isset($SimpleHead[$k]['type'])) { $type = $SimpleHead[$k]['type']; $AllowArray = $SimpleHead[$k]['allowarray']; } //設(shè)置單元格的數(shù)據(jù)驗(yàn)證 if($type) { switch ($type) { case 'list': self::setSelectionRange($sheet, $StartCol,$AllowArray); break; case 'range': self::setValueRange($sheet, $StartCol,$AllowArray); break; } } } $row ++ ; } } /* * 生成Execl單元格備注 * $sheet 當(dāng)前的工作簿對(duì)象 * $Cell 需要設(shè)置屬性的單元格 * $content 備注內(nèi)容 * */ private static function setComment($sheet,$Cell,$content) { $sheet->getComment($Cell)->setAuthor('4399om'); $objCommentRichText = $sheet->getComment($Cell)->getText()->createTextRun('4399om:'); $objCommentRichText->getFont()->setBold(true); $sheet->getComment($Cell)->getText()->createTextRun("\r\n"); $sheet->getComment($Cell)->getText()->createTextRun($content); $sheet->getComment($Cell)->setWidth('100pt'); $sheet->getComment($Cell)->setHeight('100pt'); $sheet->getComment($Cell)->setMarginLeft('150pt'); $sheet->getComment($Cell)->getFillColor()->setRGB('EEEEEE'); } /* * 現(xiàn)在單元格的有效數(shù)據(jù)范圍,暫時(shí)僅限于數(shù)字 * $sheet 當(dāng)前的工作簿對(duì)象 * $Cell 需要設(shè)置屬性的單元格 * $ValueRange array 允許輸入數(shù)組的訪問(wèn) */ private static function setValueRange($sheet,$Cell,$ValueRange) { //設(shè)置單元格的的數(shù)據(jù)類(lèi)型是數(shù)字,并且保留有效位數(shù) $sheet->getStyle($Cell)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER_00); $ValueRange = explode(",",$ValueRange); //開(kāi)始數(shù)值有效訪問(wèn)設(shè)定 $objValidation = $sheet->getCell($Cell)->getDataValidation(); $objValidation->setType( PHPExcel_Cell_DataValidation:: TYPE_WHOLE ); $objValidation->setErrorStyle( PHPExcel_Cell_DataValidation:: STYLE_STOP ); $objValidation->setAllowBlank(true); $objValidation->setShowInputMessage( true); //設(shè)置顯示提示信息 $objValidation->setShowErrorMessage( true); //設(shè)置顯示錯(cuò)誤信息 $objValidation->setErrorTitle('輸入錯(cuò)誤'); //錯(cuò)誤標(biāo)題 $objValidation->setError('請(qǐng)輸入數(shù)據(jù)范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //錯(cuò)誤內(nèi)容 $objValidation->setPromptTitle('允許輸入'); //設(shè)置提示標(biāo)題 $objValidation->setPrompt('請(qǐng)輸入數(shù)據(jù)范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //提示內(nèi)容 $objValidation->setFormula1($ValueRange['0']); //設(shè)置最大值 $objValidation->setFormula2($ValueRange['1']); //設(shè)置最小值 } private static function OutinputHeader($objWriter) { $fileName = str_replace('.php', '.xlsx', pathinfo(__FILE__, PATHINFO_BASENAME)); header("Content-Type: application/force-download"); header("Content-Type: application/octet-stream"); header("Content-Type: application/download"); header('Content-Disposition:inline;filename="'.$fileName.'"'); header("Content-Transfer-Encoding: binary"); header("Last-Modified: " . gmdate("D, d M Y H:i:s") . " GMT"); header("Cache-Control: must-revalidate, post-check=0, pre-check=0"); header("Pragma: no-cache"); $objWriter->save('php://output'); exit; } //數(shù)據(jù)控制,設(shè)置單元格數(shù)據(jù)在一個(gè)可選方位類(lèi) private static function setSelectionRange($sheet,$Cell,$rangeStr,$Title="數(shù)據(jù)類(lèi)型") { $objValidation = $sheet->getCell($Cell)->getDataValidation(); $objValidation -> setType(PHPExcel_Cell_DataValidation::TYPE_LIST) -> setErrorStyle(PHPExcel_Cell_DataValidation::STYLE_STOP) -> setAllowBlank(true) -> setShowInputMessage(true) -> setShowErrorMessage(true) -> setShowDropDown(true) -> setErrorTitle('輸入的值有誤') -> setError('您輸入的值不在下拉框列表內(nèi).') -> setPromptTitle('"'.$Title.'"') -> setFormula1('"'.$rangeStr.'"'); } /* * 構(gòu)建表頭 * */ public static function RecursionCreateExecl($head,$data) { $PHPExecl = new PHPExcel(); $objWriter = self::createWriter($PHPExecl, 'Excel2007'); $PHPExecl->getProperties()->setCreator("4399om") ->setLastModifiedBy("Summer") ->setTitle("Office 2007 XLSX Test Document") ->setSubject("Office 2007 XLSX Test Document") ->setDescription("Test document for Office 2007 XLSX, generated using PHP classes.") ->setKeywords("office 2007 openxml php") ->setCategory("Test result file"); $PHPExecl->setActiveSheetIndex(0); $sheet = $PHPExecl->getActiveSheet(); self::HandleHeadToNode($sheet, $head,1,0,0); self::SummerInsertDateToExecl($sheet,$head,$data,4); self::OutinputHeader($objWriter); } private static function HandleHeadToNode($sheet,$Head,$beginRow,$col,$StartCol) { foreach($Head as $key=>$cells) { $row = $beginRow; //表示行 $beginCol = PHPExcel_Cell::stringFromColumnIndex($col).$row; $sheet->getCell($beginCol)->setValue($cells['value']); //設(shè)置表格樣式 $sheet->getStyle($beginCol)->getAlignment()->applyFromArray( array( 'horizontal'=> PHPExcel_Style_Alignment::HORIZONTAL_CENTER, 'vertical' => PHPExcel_Style_Alignment::VERTICAL_CENTER, 'rotation' => 0, 'wrap' => TRUE, ) ); $sheet->getStyle($beginCol)->getFont()->getColor()->setARGB(PHPExcel_Style_Color::COLOR_DARKGREEN); //設(shè)置單元格的寬度 if(isset($cells['width'])) { $Cell = $sheet->getColumnDimension(PHPExcel_Cell::stringFromColumnIndex($col)); $Cell->setWidth($cells['width']); } //哥元素打上標(biāo)記 if(isset($cells['Content'])) { self::setComment($sheet, $beginCol, $cells['Content']); } $merge = false; //合并單元格 if(isset($cells['col'])) { $col += $cells['col']-1; $merge = true; } if(isset($cells['row'])) { $row += $cells['row']-1; $merge = true; } if($merge) { $endCol = PHPExcel_Cell::stringFromColumnIndex($col).$row; $sheet->mergeCells($beginCol.":".$endCol); } $row ++; $col ++; //表示有存在孩子節(jié)點(diǎn) if(isset($cells['children']) && is_array($cells['children'])){ $cols = $StartCol; if(!self::IsExistChildren($cells['children'])) { $cols = $col-2; $StartCol = $col; } self::HandleHeadToNode($sheet,$cells['children'],$row,$cols,$StartCol); }else{ $StartCol = $col; } } } //判斷自己的孩子節(jié)點(diǎn)中是否存在孫子節(jié)點(diǎn) private static function IsExistChildren($Data) { foreach($Data as $key=>$value) { if(isset($value['children']) && is_array($value['children'])) { return true; } } return false; } //獲取底層數(shù)據(jù) private static function getHead($Head,&$Node=array()) { foreach($Head as $key=>$value) { if(isset($value['children']) && is_array($value['children'])) { self::getHead($value['children'],$Node); } else { $Node[] = $value; } } return $Node; } } $Head = array( array('value'=>'姓名','col'=>2,'row'=>2,'width'=>20,'type'=>'list','allowarray'=>'PHP開(kāi)發(fā)工程師,PHP開(kāi)發(fā)'), array('value'=>'第一天','col'=>2,'row'=>1,'width'=>20,'Content'=>'2014-12-29號(hào)', 'children'=> array( array('value'=>'上午','col'=>1,'width'=>20,'type'=>'range','allowarray'=>'10,100'), array('value'=>'下午','width'=>20), ), ), array('value'=>'第二天','col'=>2,'row'=>1,'width'=>20, 'children'=> array( array('value'=>'上午','width'=>20), array('value'=>'下午','width'=>20), ), ), ); $data = array( array('PHP開(kāi)發(fā)工程師','12','吃飯1','睡覺(jué)1','起床刷牙2','吃飯睡覺(jué)2'), array('PHP開(kāi)發(fā)工程師','25','吃飯1','睡覺(jué)1','起床刷牙2','吃飯睡覺(jué)2'), array('PHP開(kāi)發(fā)工程師','50','吃飯1','睡覺(jué)1','起床刷牙2','吃飯睡覺(jué)2'), array('PHP開(kāi)發(fā)工程師','99','吃飯1','睡覺(jué)1','起床刷牙2','吃飯睡覺(jué)2'), array('PHP開(kāi)發(fā)工程師','10','吃飯1','睡覺(jué)1','起床刷牙2','吃飯睡覺(jué)2'), ); $Node = PHPExeclCore::RecursionCreateExecl($Head,$data);
得到的效果也基本符合需求:
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《php操作office文檔技巧總結(jié)(包括word,excel,access,ppt)》、《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》、《php正則表達(dá)式用法總結(jié)》、《PHP運(yùn)算與運(yùn)算符用法總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見(jiàn)數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- PHP轉(zhuǎn)換文本框內(nèi)容為HTML格式的方法
- 使用PHP+JavaScript將HTML頁(yè)面轉(zhuǎn)換為圖片的實(shí)例分享
- PHP將HTML轉(zhuǎn)換成文本的實(shí)現(xiàn)代碼
- php中將html中的br換行符轉(zhuǎn)換為文本輸入中的換行符
- 基于php導(dǎo)出到Excel或CSV的詳解(附utf8、gbk 編碼轉(zhuǎn)換)
- php使用Image Magick將PDF文件轉(zhuǎn)換為JPG文件的方法
- 利用PHP將圖片轉(zhuǎn)換成base64編碼的實(shí)現(xiàn)方法
- PHP 實(shí)現(xiàn)的將圖片轉(zhuǎn)換為T(mén)XT
- php將圖片文件轉(zhuǎn)換成二進(jìn)制輸出的方法
- php圖片的二進(jìn)制轉(zhuǎn)換實(shí)現(xiàn)方法
相關(guān)文章
php動(dòng)態(tài)生成版權(quán)所有信息的方法
這篇文章主要介紹了php動(dòng)態(tài)生成版權(quán)所有信息的方法,實(shí)例分析了php時(shí)間與字符串的操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03PHP根據(jù)手機(jī)號(hào)判斷運(yùn)營(yíng)商(詳細(xì)介紹附代碼)
這篇文章主要介紹了PHP根據(jù)手機(jī)號(hào)判斷運(yùn)營(yíng)商,詳細(xì)介紹附代碼,大家可以根據(jù)最新的號(hào)段進(jìn)行添加即可,通過(guò)正則判斷實(shí)現(xiàn),需要的朋友可以參考下2018-01-01/etc/php-fpm.d/www.conf 配置注意事項(xiàng)
下面小編就為大家?guī)?lái)一篇/etc/php-fpm.d/www.conf 配置注意事項(xiàng)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-02-02php中實(shí)現(xiàn)獲取隨機(jī)數(shù)組列表的自定義函數(shù)
這篇文章主要介紹了php中實(shí)現(xiàn)獲取隨機(jī)數(shù)組列表的自定義函數(shù),本文直接給出實(shí)現(xiàn)代碼,需要的朋友可以參考下2015-04-04