基于PHPexecl类生成复杂的报表表头示例

5年以前  |  阅读数:445 次  |  编程语言:PHP 

本文实例讲述了基于PHPexecl类生成复杂的报表表头。分享给大家供大家参考,具体如下:

以前一直有需求,能把Execl里面的数据导入数据库,并且把数据库里面的数据导出到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工作簿的数量
     for($i=0;$i<$sheetCount;$i++)
     {
     $ActiveSheet = $PHPExeclObj->getSheet($i);
     $highestRow = $ActiveSheet->getHighestRow(); // 取得总列数
     $allColumn = $ActiveSheet->getHighestColumn();
     //通过嵌套循环来读取sheet工作簿里面的内容
     for($Col='A';$Col<$allColumn;$Col++)
     {
     for($Row=1;$Row<$highestRow;$Row++)
     {
     $Data[$Col][$Row] = $ActiveSheet->getCell($Col.$Row)->getValue();
     }
     }
     }
     }
     return $Data;
     }
     /*
     * 将数据写入到数据表中
     * $Data Array 表示要插入进Execl数据
     * $RuleData Array 表示数据格式的规则数组
     * $i int 表示从第几行起的插入数据
     * **/
     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'];
     }
     //设置单元格的数据验证
     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 备注内容
     * */
     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');
     }
     /*
     * 现在单元格的有效数据范围,暂时仅限于数字
     * $sheet 当前的工作簿对象
     * $Cell 需要设置属性的单元格
     * $ValueRange array 允许输入数组的访问
     */
     private static function setValueRange($sheet,$Cell,$ValueRange)
     {
     //设置单元格的的数据类型是数字,并且保留有效位数
     $sheet->getStyle($Cell)->getNumberFormat()->setFormatCode(PHPExcel_Style_NumberFormat::FORMAT_NUMBER_00);
     $ValueRange = explode(",",$ValueRange);
     //开始数值有效访问设定
     $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('请输入数据范围在从'.$ValueRange[0].'到'.$ValueRange[1].'之间的所有值'); //错误内容
     $objValidation->setPromptTitle('允许输入'); //设置提示标题
     $objValidation->setPrompt('请输入数据范围在从'.$ValueRange[0].'到'.$ValueRange[1].'之间的所有值'); //提示内容
     $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;
     }
     //数据控制,设置单元格数据在一个可选方位类
     private static function setSelectionRange($sheet,$Cell,$rangeStr,$Title="数据类型")
     {
     $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('您输入的值不在下拉框列表内.')
     -> setPromptTitle('"'.$Title.'"')
     -> setFormula1('"'.$rangeStr.'"');
     }
     /*
     * 构建表头
     * */
     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 ++;
     //表示有存在孩子节点
     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;
     }
     }
     }
     //判断自己的孩子节点中是否存在孙子节点
     private static function IsExistChildren($Data)
     {
     foreach($Data as $key=>$value)
     {
     if(isset($value['children']) && is_array($value['children']))
     {
     return true;
     }
     }
     return false;
     }
     //获取底层数据
     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开发工程师,PHP开发'),
     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开发工程师','12','吃饭1','睡觉1','起床刷牙2','吃饭睡觉2'),
     array('PHP开发工程师','25','吃饭1','睡觉1','起床刷牙2','吃饭睡觉2'),
     array('PHP开发工程师','50','吃饭1','睡觉1','起床刷牙2','吃饭睡觉2'),
     array('PHP开发工程师','99','吃饭1','睡觉1','起床刷牙2','吃饭睡觉2'),
     array('PHP开发工程师','10','吃饭1','睡觉1','起床刷牙2','吃饭睡觉2'),
     );
    $Node = PHPExeclCore::RecursionCreateExecl($Head,$data);

得到的效果也基本符合需求:

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php操作office文档技巧总结(包括word,excel,access,ppt)》、《PHP数组(Array)操作技巧大全》、《php排序算法总结》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》、《PHP数学运算技巧总结》、《php正则表达式用法总结》、《PHP运算与运算符用法总结》、《php字符串(string)用法总结》及《php常见数据库操作技巧汇总

希望本文所述对大家PHP程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例