php导出excel表格的原理
内容导读
收集整理的这篇技术教程文章主要介绍了php导出excel表格的原理,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2533字,纯文字阅读大概需要4分钟。
内容图文
在了解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表格的原理的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是为您收集整理的php导出excel表格的原理全部内容,希望文章能够帮你解决php导出excel表格的原理所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
希望以上内容对你有所帮助!如果还有其他问题,请随时提问。 各类知识收集 拥有多年CMS企业建站经验,对 lecms, classcms, fastadmin, pbootcms, phpcms, eyoucms, yzmcms, PHP, xunruicms, jizhicms, dedecms, wordpress, hkcms, yzncms, 等各类cms的相互转化,程序开发,网站制作,bug修复,程序杀毒,插件定制都可以提供最佳解决方案。