基于PHPexecl類生成復雜的報表表頭示例
本文實例講述了基于PHPexecl類生成復雜的報表表頭。分享給大家供大家參考,具體如下:
以前一直有需求,能把Execl里面的數(shù)據(jù)導入數(shù)據(jù)庫,并且把數(shù)據(jù)庫里面的數(shù)據(jù)導出到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();
//通過嵌套循環(huán)來讀取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ù)寫入到數(shù)據(jù)表中
* $Data Array 表示要插入進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ù)據(jù)驗證
if($type)
{
switch ($type)
{
case 'list':
self::setSelectionRange($sheet, $StartCol,$AllowArray);
break;
case 'range':
self::setValueRange($sheet, $StartCol,$AllowArray);
break;
}
}
}
$row ++ ;
}
}
/*
* 生成Execl單元格備注
* $sheet 當前的工作簿對象
* $Cell 需要設置屬性的單元格
* $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ù)字
* $sheet 當前的工作簿對象
* $Cell 需要設置屬性的單元格
* $ValueRange array 允許輸入數(shù)組的訪問
*/
private static function setValueRange($sheet,$Cell,$ValueRange)
{
//設置單元格的的數(shù)據(jù)類型是數(shù)字,并且保留有效位數(shù)
$sheet->getStyle($Cell)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER_00);
$ValueRange = explode(",",$ValueRange);
//開始數(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); //設置顯示提示信息
$objValidation->setShowErrorMessage( true); //設置顯示錯誤信息
$objValidation->setErrorTitle('輸入錯誤'); //錯誤標題
$objValidation->setError('請輸入數(shù)據(jù)范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //錯誤內(nèi)容
$objValidation->setPromptTitle('允許輸入'); //設置提示標題
$objValidation->setPrompt('請輸入數(shù)據(jù)范圍在從'.$ValueRange[0].'到'.$ValueRange[1].'之間的所有值'); //提示內(nèi)容
$objValidation->setFormula1($ValueRange['0']); //設置最大值
$objValidation->setFormula2($ValueRange['1']); //設置最小值
}
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ù)據(jù)在一個可選方位類
private static function setSelectionRange($sheet,$Cell,$rangeStr,$Title="數(shù)據(jù)類型")
{
$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']);
//設置表格樣式
$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);
//設置單元格的寬度
if(isset($cells['width']))
{
$Cell = $sheet->getColumnDimension(PHPExcel_Cell::stringFromColumnIndex($col));
$Cell->setWidth($cells['width']);
}
//哥元素打上標記
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é)點
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é)點中是否存在孫子節(jié)點
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開發(fā)工程師,PHP開發(fā)'),
array('value'=>'第一天','col'=>2,'row'=>1,'width'=>20,'Content'=>'2014-12-29號',
'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開發(fā)工程師','12','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'),
array('PHP開發(fā)工程師','25','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'),
array('PHP開發(fā)工程師','50','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'),
array('PHP開發(fā)工程師','99','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'),
array('PHP開發(fā)工程師','10','吃飯1','睡覺1','起床刷牙2','吃飯睡覺2'),
);
$Node = PHPExeclCore::RecursionCreateExecl($Head,$data);
得到的效果也基本符合需求:

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php操作office文檔技巧總結(jié)(包括word,excel,access,ppt)》、《PHP數(shù)組(Array)操作技巧大全》、《php排序算法總結(jié)》、《PHP常用遍歷算法與技巧總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設計算法總結(jié)》、《PHP數(shù)學運算技巧總結(jié)》、《php正則表達式用法總結(jié)》、《PHP運算與運算符用法總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
- PHP轉(zhuǎn)換文本框內(nèi)容為HTML格式的方法
- 使用PHP+JavaScript將HTML頁面轉(zhuǎn)換為圖片的實例分享
- PHP將HTML轉(zhuǎn)換成文本的實現(xiàn)代碼
- php中將html中的br換行符轉(zhuǎn)換為文本輸入中的換行符
- 基于php導出到Excel或CSV的詳解(附utf8、gbk 編碼轉(zhuǎn)換)
- php使用Image Magick將PDF文件轉(zhuǎn)換為JPG文件的方法
- 利用PHP將圖片轉(zhuǎn)換成base64編碼的實現(xiàn)方法
- PHP 實現(xiàn)的將圖片轉(zhuǎn)換為TXT
- php將圖片文件轉(zhuǎn)換成二進制輸出的方法
- php圖片的二進制轉(zhuǎn)換實現(xiàn)方法
相關(guān)文章
/etc/php-fpm.d/www.conf 配置注意事項
下面小編就為大家?guī)硪黄?etc/php-fpm.d/www.conf 配置注意事項。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
php中實現(xiàn)獲取隨機數(shù)組列表的自定義函數(shù)
這篇文章主要介紹了php中實現(xiàn)獲取隨機數(shù)組列表的自定義函數(shù),本文直接給出實現(xiàn)代碼,需要的朋友可以參考下2015-04-04

