欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

php导出excel表格的原理

程序员文章站 2022-04-11 10:09:15
...

php导出excel表格的原理

在了解php是如何导出excel表格之前先了解一下excel的本质

excel分为两大版本excel2007(后缀.xlsx)、excel2003(后缀.xls),excel2007本质是xml的一个集合文档(压缩文档),excel2007文档的组成就是xml的集合压缩文档。excel2003:本质是一个二进制文件。

了解了excel,就下来介绍介绍php导出excel的原理:

对于excel2007来说,由于其本质为xml的集合文档,所以导出过程就是解析xml的过程;对于excel2003来说,由于其本质是二进制文件,所以,导出excel的过程首先会打开二进制文件,然后读取内部信息,并把内部信息转化为可以识别的内容的过程。

两种导出方式

方式一:使用PHPExcel类库

//引入PHPExcel库文件(路径根据自己情况)
include './phpexcel/Classes/PHPExcel.php';
$excel = new PHPExcel(); //创建对象
$letter = array('A','B','C','D','E','F','F','G'); //Excel表格式,这里简略写了8列
$tableheader = array('学号','姓名','性别','年龄','班级');//表头数组
//填充表头信息
for($i = 0;$i < count($tableheader);$i++) {
$excel->getActiveSheet()->setCellValue("$letter[$i]1","$tableheader[$i]");
}
$data = array(
array('1','小王','男','20','100'),
array('2','小李','男','20','101'),
array('3','小张','女','20','102'),
array('4','小赵','女','20','103')
);
//填充表格信息
for ($i = 2;$i <= count($data) + 1;$i++) {
$j = 0;
foreach ($data[$i - 2] as $key=>$value) {
$excel->getActiveSheet()->setCellValue("$letter[$j]$i","$value");
$j++;
}
}
$write = new PHPExcel_Writer_Excel5($excel);
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="testdata.xls"');
header("Content-Transfer-Encoding:binary");
$write->save('php://output');

方式二:简单的PHP导出excel,不适用任何外部类库文件

header("Content-type: text/csv");
header("Content-Disposition: attachment; filename=reply.csv");
header("Pragma: no-cache");
header("Expires: 0");
$output = fopen("php://output", "w");
$header = array('学号','姓名','性别','年龄','班级');
$converter = function($value) {
return iconv('utf-8', 'gbk', $value);
};
$header = array_map($converter, $header);
$list = array(
array('1','小王','男','20','100'),
array('2','小李','男','20','101'),
array('3','小张','女','20','102'),
array('4','小赵','女','20','103')
);
fputcsv($output, $header);
foreach($list as $k => $v)
{
$csvrow = array_map($converter, array(
$v[0],
$v[1],
$v[2],
$v[3],
$v[4],

));
fputcsv($output, $csvrow);
}
fclose($output);

以上内容仅供参考!

想了解更多相关内容请访问PHP中文网:PHP视频教程

以上就是php导出excel表格的原理的详细内容,更多请关注其它相关文章!

相关标签: php 导出 excel