您现在的位置是:网站首页>PHP技术PHP技术

TP5使用PHPExcel插件导出数据到表格的方法

草谷2019-04-27PHP技术

简介使用PHPExcel插件导出数据到excel表格的用法

分享一下PHPExcel在thinkphp5框架中的用法

首先下载PHPExcel类库放到extend目录下,路径如下图


657DA383-C432-4FC1-91E5-0007CF526039.png


业务处理方法如下,我把它放到了application/common.php中,方便在任何控制器中可以直接通过方法名来调用它

/**
 * 导出数据到excel表格
 * @param $expTitle
 * @param $expCellName
 * @param $expTableData
 */
function exportExcel($expTitle, $expCellName, $expTableData)
{
    include_once EXTEND_PATH . 'PHPExcel/PHPExcel.php'; //方法二
    $xlsTitle = iconv('utf-8', 'gb2312', $expTitle); //文件名称
    $fileName = $expTitle . date('_YmdHis'); //or $xlsTitle 文件名称可根据自己情况设定
    $cellNum  = count($expCellName);
    $dataNum  = count($expTableData);
//        $objPHPExcel = new PHPExcel();//方法一
    $objPHPExcel = new \PHPExcel(); //方法二
    $cellName    = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI', 'AJ', 'AK', 'AL', 'AM', 'AN', 'AO', 'AP', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AV', 'AW', 'AX', 'AY', 'AZ');
    $objPHPExcel->getActiveSheet(0)->mergeCells('A1:' . $cellName[$cellNum - 1] . '1'); //合并单元格
    $objPHPExcel->setActiveSheetIndex(0)->setCellValue('A1', $expTitle . '  Export time:' . date('Y-m-d H:i:s'));
    for ($i = 0; $i < $cellNum; $i++) {
        $objPHPExcel->setActiveSheetIndex(0)->setCellValue($cellName[$i] . '2', $expCellName[$i][1]);
    }
    // Miscellaneous glyphs, UTF-8
    for ($i = 0; $i < $dataNum; $i++) {
        for ($j = 0; $j < $cellNum; $j++) {
            $objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);
        }
    }
    ob_end_clean(); //这一步非常关键,用来清除缓冲区防止导出的excel乱码
    header('pragma:public');
    header('Content-type:application/vnd.ms-excel;charset=utf-8;name="' . $xlsTitle . '.xls"');
    header("Content-Disposition:attachment;filename=$fileName.xls"); //"xls"参考下一条备注
    $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5'); //"Excel2007"生成2007版本的xlsx,"Excel5"生成2003版本的xls
    $objWriter->save('php://output');
    exit;
}


在控制器中调用的方法也非常简单,类似下面的demo

    //表明
    $xlsName  = "export";
    //表头的名称以及对应表内容的key名
    $xlsCell  = array(
        array('uid','账号序列'),
        array('nickname','名字'),
        array('email','邮箱'),
    );
    //表的内容,直接通过取到的数据根据实际情况进行业务处理
    $xlsData  = Db::name('表名')->Field('uid,nickname,email')->select();
    //调用上述的exportExcel方法,并传入表名、表头和内容数组即可
    exportExcel($xlsName,$xlsCell,$xlsData);


类库附件在这里,点击下载:PHPExcel.tar.gz


很赞哦! (2)

文章评论