使用PHPExcel导入导出excel格式文件

使用PHPExcel导入导出excel格式文件

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

使用PHPExcel导入导出excel格式文件 


作者:zccst 




因为导出使用较多,以下是导出实现过程。 




第一步,将PHPExcel的源码拷贝到项目的lib下 




文件包含:PHPExcel.php 和 目录PHPExcel 


源码见附件 




注1:源码是zip格式,能在windows和linux通用。 


注2:PHPExcel.zip是干净代码,能够直接引用。PHPExcel2.zip有svn记录,不适合直接引用。 




第二步:在须要导出的handler页面中引用 




1,在头部引入三个文件 

Php代码  
收藏代码

  1. //环境变量设置(新增PHPExcel)  
  2. set_include_path(‘.’. PATH_SEPARATOR . Yii::app()->basePath.‘/lib/PHPExcel’ . PATH_SEPARATOR . get_include_path());  
  3. //注:在yii中,也能够直接Yii::import(“application.lib.PHPExcel.*”);  
  4.   
  5. //引入PHPExcel相关文件  
  6. require_once “PHPExcel.php”;  
  7. require_once ‘PHPExcel/IOFactory.php’;  
  8. require_once ‘PHPExcel/Writer/Excel5.php’;  





2,将数据放入excel表格中 

Php代码  
收藏代码

  1. //新建  
  2. $resultPHPExcel = new PHPExcel();  
  3.   
  4. //设置參数  
  5.   
  6. //设值  
  7. $resultPHPExcel->getActiveSheet()->setCellValue(‘A1’‘季度’);  
  8. $resultPHPExcel->getActiveSheet()->setCellValue(‘B1’‘名称’);  
  9. $resultPHPExcel->getActiveSheet()->setCellValue(‘C1’‘数量’);  
  10. $i = 2;  
  11. foreach($data as $item){  
  12.     $resultPHPExcel->getActiveSheet()->setCellValue(‘A’ . $i$item[‘quarter’]);  
  13.     $resultPHPExcel->getActiveSheet()->setCellValue(‘B’ . $i$item[‘name’]);  
  14.     $resultPHPExcel->getActiveSheet()->setCellValue(‘C’ . $i$item[‘number’]);  
  15.     $i ++;  
  16. }  





3,设置导出的一些參数 


版本号一: 

Php代码  
收藏代码

  1. //设置导出文件名称  
  2. $outputFileName = ‘total.xls’;  
  3. $xlsWriter = new PHPExcel_Writer_Excel5($resultPHPExcel);  
  4. //ob_start();  ob_flush();  
  5. header(“Content-Type: application/force-download”);  
  6. header(“Content-Type: application/octet-stream”);  
  7. header(“Content-Type: application/download”);  
  8. header(‘Content-Disposition:inline;filename=”‘.$outputFileName.‘”‘);  
  9. header(“Content-Transfer-Encoding: binary”);  
  10. header(“Expires: Mon, 26 Jul 1997 05:00:00 GMT”);  
  11. header(“Last-Modified: “ . gmdate(“D, d M Y H:i:s”) . ” GMT”);  
  12. header(“Cache-Control: must-revalidate, post-check=0, pre-check=0”);  
  13. header(“Pragma: no-cache”);  
  14.   
  15. $xlsWriter->save( “php://output” );  





版本号二: 

Php代码  
收藏代码

  1. $writer = PHPExcel_IOFactory::createWriter($resultPHPExcel‘Excel5’);  
  2. $writer->setTempDir(Yii::app()->basePath.‘/runtime’);  
  3. $filename = “单.xls”;  
  4. header(“Pragma: public”);  
  5. header(“Cache-Control: must-revalidate, post-check=0, pre-check=0”);  
  6. header(“Content-Type: application/force-download”);  
  7. header(‘Content-Type: application/vnd.ms-excel’);  
  8. header(‘Content-Disposition: attachment;filename=”‘ . $filename . ‘”‘);  
  9. header(‘Cache-Control: max-age=0’);  
  10. $writer->save(‘php://output’);  





4,添加�附件(非必需) 

Php代码  
收藏代码

  1. $objPHPExcel    = new PHPExcel();  
  2. $objReader = PHPExcel_IOFactory::createReader(‘Excel5’);  
  3. $objReader->setReadDataOnly(true);  
  4.   
  5. foreach($data2 as $item){  
  6.     $fp = dirname(__FILE__) . “/../../../” . $item[‘file_path’] ;  
  7.     $objPHPExcel = $objReader->load($fp);  
  8.     $objWorksheet = $objPHPExcel->getActiveSheet();  
  9.     $resultPHPExcel->addExternalSheet($objWorksheet);  
  10. }  







高级主题
 


1,excel5与excel2007差别 


zipArchive.php 


有非常多php(php.ini)不支持excel2007,所以建议使用excel5。 






2,设置暂时文件位置 


假设报暂时文件名称错,则更改暂时文件路径 


xlsWriter.setDirName(Yii::app()->basePath.’/runtime’); 






3,设置excel单元格的格式 


过滤 




4,输出有错。 


默认$xlsWriter->save( “php://output” );可能由于缓存不够大,而显示不完整,所以做个中转,方式例如以下: 

Php代码  
收藏代码

  1. $finalFileName = (Yii::app()->basePath.‘/runtime/’.time().‘.xls’;  
  2. $xlsWriter->save($finalFileName);  
  3. echo file_get_contents($finalFileName);  //file_get_contents() 函数把整个文件读入一个字符串中。和 file() 一样,不同的是 file_get_contents() 把文件读入一个字符串。  
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118758.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • PyTorch 实现 ResNet34 分类(数据cifar10)「建议收藏」

    PyTorch 实现 ResNet34 分类(数据cifar10)「建议收藏」    又到整理的时候了,这次参考torchvision里面的resnet34源代码,自己修改了一下,实现cifar10数据集的分类任务。    其实网络上已经有很多优秀的源代码了,没必要再写,如果执意要说个理由的话,就当是自己的笔记了哈哈,方便以后使用可以快速查阅。没别的,菜鸟就应该多积累。ResNet34大体结构:图片:来自《深度学习框架PyTorch:入门与实践》PyTorch…

    2022年9月25日
    3
  • map改变一个字母是什么_map中a的发音音标

    map改变一个字母是什么_map中a的发音音标原题链接给定一个字符串数组,将字母异位词组合在一起。字母异位词指字母相同,但排列不同的字符串。示例:输入: [“eat”, “tea”, “tan”, “ate”, “nat”, “bat”]输出:[ [“ate”,”eat”,”tea”], [“nat”,”tan”], [“bat”]]说明:所有输入均为小写字母。不考虑答案输出的顺序。tclass Solution {public: vector<vector<string>> g

    2022年8月9日
    7
  • 一小时搞定简单VBA编程 Excel宏编程快速上手

    一小时搞定简单VBA编程 Excel宏编程快速上手Excel宏编程可以快速完成批量表格操作:复制粘贴、数据过滤等,宏代码基于VB语言实现,有基础的编程经验就能快速阅读。下面是我的学习笔记。1.ExcelVBA编辑界面(进入路径:sheet名称–>鼠标右键菜单–>查看代码)2.输入代码方法:在VBE编辑器的代码模块中输入VBA代码,通常有以下几种方法:■手工键盘输入;■使用宏录制器,即选择菜单“工具—…

    2022年6月6日
    46
  • iphone尺寸大全对照表2021 iphone屏幕尺寸大全

    iphone尺寸大全对照表2021 iphone屏幕尺寸大全iPhone11 6.1英寸 iPhone11Pro 5.8英寸 iphone手机爆降价1500这活动太给力了机会不容错过http://iphone.adiannao.cn/2iPhone11ProMax 6.5英寸iPhoneSE2020款 4.7英寸 iPhone12mini 5.4英寸 iPhone12 6.1英寸 iPhone12Pro 6.1英寸 iPhone12ProMax 6.7英寸第一代iPhone2GiOS1

    2022年5月15日
    1.0K
  • oracle未明确定义列[通俗易懂]

    oracle未明确定义列[通俗易懂]分类:SQL使用技巧2012-04-0616:121332人阅读评论(0)收藏举报运行环境:Oracle10gsqlplus环境下。 在查询语句中,经常会出现一个错误: SQL基础:ORA-00918:未明确定义列的错误。 当前遇到有两种情况。原因为:当查询语句中,查询的表(数据集)中有相同的字

    2022年10月5日
    4
  • JVM调优工具总结

    JVM调优工具总结一、jps:虚拟机进程状况工具它可以列出正在运行的虚拟机进程,并显示虚拟机执行主类(MainClass,main()函数所在的类)名称以及正在运行的本地虚拟机唯一ID(LVMID);它是使用率最高的一个JDK命令行工具,因为其他的命令行工具都需要输入查询到的ID来确定要监控的是哪一个虚拟机进程。命令格式:jps[options][hostid]选项作用-q只…

    2022年5月6日
    37

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号