php导出excel单元格带图片显示方法如下:<?php
session_start();
set_time_limit(0);
header("content-type:text/html; charset=utf-8");
error_reporting(E_ALL ^ E_NOTICE); //除了 E_NOTICE,报告其他所有错误,
这是在 php.ini 里的默认设置
@set_time_limit(1000); //设置脚本最大执行时间为1000秒并忽略函数错误,
运用了@错误控制运算符
@date_default_timezone_set("PRC"); //设置时区
date_default_timezone_set('Asia/Shanghai');
function test_input($data) {
$data=trim($data);
$data=stripslashes($data);
$data=htmlspecialchars($data);
return $data;
}
/*引入phpexcel核心类文件*/
include 'Classes/PHPExcel.php';
/*实例化excel类*/
$excel = new PHPExcel();
/*实例化excel图片处理类*/
$objDrawing = new PHPExcel_Worksheet_Drawing();
/*设置文本对齐方式*/
$excel->getDefaultStyle()->getAlignment()
->setHorizontal(PHPExcel_Style_Alignment::HORIZONTAL_CENTER);
$excel->getDefaultStyle()->getAlignment()
->setVertical(PHPExcel_Style_Alignment::VERTICAL_CENTER);
//获得当前sheet对象
$objActSheet = $excel->getActiveSheet();
$excel->getActiveSheet()->setTitle('处理表'); //给当前活动sheet设置名称
//定义单元格列名
$letter = array('A','B','C','D','E','F','G','H','I','J','K','L','M','N');
/*设置表头数据*/
$tableheader = array('姓名', '性别', '年龄', '班级', '头像');
//给当前活动sheet填充数据,数据填充是按顺序一行一行填充的,
假如想给A1留空,可以直接setCellValue(‘A1’,’’);
// $excel->getActiveSheet()->setCellValue('A1', 'ID')
// ->setCellValue('B1', '姓名')
// ->setCellValue('C1', '手机号')
// ->setCellValue('D1', '业务需求')
// ->setCellValue('E1', '处理人姓名')
// ->setCellValue('F1', '创建时间')
// ->setCellValue('G1', '是否处理')
// ;
/*填充表格表头*/
for($i = 0;$i
$excel->getActiveSheet()->setCellValue("$letter[$i]1","$tableheader[$i]");
}
/*设置表格数据*/
$data = array(
array('小王', '男', '20', 'CS12', 'PVC/HML55686.jpg'),
array('小李', '女', '21', 'CS12', 'PVC/HML55686.jpg'),
array('小马', '男', '22', 'CS12', 'PVC/HML55686.jpg'),
array('小赵', '女', '23', 'CS12', 'PVC/HML55686.jpg'),
array('小张', '男', '24', 'CS12', 'PVC/HML55686.jpg')
);
/*填充表格内容*/
for ($i = 0;$i
$j = $i + 2;
/*设置表格宽度*/
$objActSheet->getColumnDimension("$letter[$i]")->setWidth(20);
/*设置表格高度*/
$excel->getActiveSheet()->getRowDimension($j)->setRowHeight(100);
/*向每行单元格插入数据*/
for ($row = 0;$row
if ($row == (count($data[$i]) -1 )) {
/*实例化插入图片类*/
$objDrawing = new PHPExcel_Worksheet_Drawing();
/*设置图片路径 切记:只能是本地图片*/
$objDrawing->setPath($data[$i][$row]);
/*默认是按原图像缩放,设置成false为不缩放*/
$objDrawing->setResizeProportional(false);
/*设置图片高度*/
$objDrawing->setWidth(140);
$objDrawing->setHeight(130);
/*设置图片要插入的单元格*/
$objDrawing->setCoordinates("$letter[$row]$j");
/*设置图片所在单元格的格式*/
$objDrawing->setOffsetX(0);
$objDrawing->setOffsetY(0);
$objDrawing->setWorksheet($excel->getActiveSheet());
continue;
}
$excel->getActiveSheet()->setCellValue("$letter[$row]$j",$data[$i][$row]);
}
}
/*实例化excel输入类并完成输出excel文件*/
$write = new PHPExcel_Writer_Excel5($excel);//按照指定格式生成Excel
文件,‘PHPExcel_Writer_Excel2007’表示生成2007版本的xlsx
header("Pragma: public");
header("Expires: 0");
header("Cache-Control:must-revalidate, post-check=0, pre-check=0");
header("Content-Type:application/force-download");
header("Content-Type:application/vnd.ms-execl");
header("Content-Type:application/octet-stream");
header("Content-Type:application/download");;
header('Content-Disposition:attachment;filename="2019-8.xls"');
header("Content-Transfer-Encoding:binary");
$write->save('php://output');
?>
注意:php读取excel表,这里采用了PHPExcel插件,可以去https://github.com/PHPOffice/PHPExcel下载插件即可配合上面代码使用。
【打印本页】
【关闭窗口】