zoukankan      html  css  js  c++  java
  • php生成excel范例,支持任意行列

    因为项目多语言化,需要做一个语言包和excel快速转换的功能,下面代码需要PHPExcel插件支持
     
    <?php
    /**
     * PHPEXCEL生成excel文件
     * @author:firmy
     * @mail:firmy@foxmail.com
     * @desc 支持任意行列数据生成excel文件,暂未添加单元格样式和对齐
     */
    require_once 'library/PHPExcel.php';
    require_once 'library/PHPExcel/Reader/Excel2007.php';
    require_once 'library/PHPExcel/Reader/Excel5.php';
    include_once 'library/PHPExcel/IOFactory.php';
    $fileName = "test_excel";
    $headArr = array("第一列","第二列","第三列");
    $data = array(array(1,2),array(1,3),array(5,7));
    getExcel($fileName,$headArr,$data);
    function getExcel($fileName,$headArr,$data){
        if(empty($data) || !is_array($data)){
            die("data must be a array");
        }
        if(empty($fileName)){
            exit;
        }
        $date = date("Y_m_d",time());
        $fileName .= "_{$date}.xlsx";
        //创建新的PHPExcel对象
        $objPHPExcel = new PHPExcel();
        $objProps = $objPHPExcel->getProperties();
        
        //设置表头
        $key = ord("A");
        foreach($headArr as $v){
            $colum = chr($key);
            $objPHPExcel->setActiveSheetIndex(0) ->setCellValue($colum.'1', $v);
            $key += 1;
        }
        
        $column = 2;
        $objActSheet = $objPHPExcel->getActiveSheet();
        foreach($data as $key => $rows){ //行写入
            $span = ord("A");
            foreach($rows as $keyName=>$value){// 列写入
                $j = chr($span);
                $objActSheet->setCellValue($j.$column, $value);
                $span++;
            }
            $column++;
        }
        $fileName = iconv("utf-8""gb2312", $fileName);
        //重命名表
        $objPHPExcel->getActiveSheet()->setTitle('Simple');
        //设置活动单指数到第一个表,所以Excel打开这是第一个表
        $objPHPExcel->setActiveSheetIndex(0);
        //将输出重定向到一个客户端web浏览器(Excel2007)
              header('Content-Type: application/vnd.openxmlformats-officedocument.spreadsheetml.sheet');
              header("Content-Disposition: attachment; filename=\"$fileName\"");
              header('Cache-Control: max-age=0');
              $objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel2007');
              if(!empty($_GET['excel'])){
                $objWriter->save('php://output'); //文件通过浏览器下载
            }else{
              $objWriter->save($fileName); //脚本方式运行,保存在当前目录
            }
      exit;
    }



  • 相关阅读:
    金融系列10《发卡行脚本》
    金融系列9《发卡行认证》
    金融系列8《应用密文产生》
    ED/EP系列5《消费指令》
    ED/EP系列4《圈存指令》
    ED/EP系列2《文件结构》
    ED/EP系列1《简介》
    社保系列11《ATR》
    社保系列3《文件结构》
    社保系列2《文件系统》
  • 原文地址:https://www.cnblogs.com/firmy/p/2783815.html
Copyright © 2011-2022 走看看