TypechoJoeTheme

Frozen个人随笔

admin

网站页面
标签搜索

thinPHP导出excel表格带有图片的方法

thinPHP导入导出excel表格带有图片的方法
导出的excel有时候带有图片无法处理,下面是导出excel中带有图片的方法
代码如下

/**
 * 查询数据进行处理
 * 导出Excel
 */
public function expUser()
{//导出Excel
    $xlsName = "User";
    $xlsCell = array(
        array('id', '账号序列'),
        array('username', '名字'),
        array('avatar', '头像')
    );
    $xlsModel = new \app\admin\model\User();

    $xlsData = $xlsModel->Field('id,username,avatar')->select();

// foreach ($xlsData as $k => $v)
// {
// $xlsData[$k]['sex']=$v['sex']==1?'男':'女';
// }

    $this->exportExcel($xlsName, $xlsCell, $xlsData);

}

============================================================================
//调用方法
public function exportExcel($expTitle, $expCellName, $expTableData)

{
    $xlsTitle = iconv('utf-8', 'gb2312', $expTitle);//文件名称

// $fileName = $_SESSION['account'].date('_YmdHis');//or $xlsTitle 文件名称可根据自己情况设定

    $fileName = date('_YmdHis');//or $xlsTitle 文件名称可根据自己情况设定

    $cellNum = count($expCellName);
    $dataNum = count($expTableData);
    vendor("PHPExcel.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++) {
            if ($expCellName[$j][0] == 'avatar') {
                $objDrawing = new \PHPExcel_Worksheet_Drawing();
                $path = $expTableData[$i][$expCellName[$j][0]];
                $objDrawing->setPath(substr($path, 1, strlen($path)));
                $objDrawing->setHeight(20);//设置图片高度
                $objDrawing->setWidth(40);//设置图片宽度
                $objDrawing->setCoordinates($cellName[$j] . ($i + 3));
                $objDrawing->setOffsetX(12);//设置图片偏移x轴
                $objDrawing->setOffsetY(12);//设置图片偏移y轴
                $objDrawing->setWorksheet($objPHPExcel->getActiveSheet(0));
                $objPHPExcel->getActiveSheet(0)->getRowDimension($i + 3)->setRowHeight(50);//设置图片所在单元格大小
            } else {
                $objPHPExcel->getActiveSheet(0)->setCellValue($cellName[$j] . ($i + 3), $expTableData[$i][$expCellName[$j][0]]);//正常无图片的单元格
            }
        }
    }
    header('pragma:public');
    header('Content-type:application/vnd.ms-excel;charset=utf-8;name="' . $xlsTitle . '.xls"');
    header("Content-Disposition:attachment;filename=$fileName.xls");//attachment新窗口打印inline本窗口打印
    $objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
    $objWriter->save('php://output');
    exit;
}
赞 · 0
评论 (0)