因为实际情况的需要,导出excel表格在后台开发的过程中会经常用到。下面是我在实际应用中自己整理的一个导出excel类,需要PHPExcel支持,本类很好的完成导出表格的基本样式,保存路径,切换工作薄写入的功能,希望对大家有所帮助。

1:需要PHPExcel支持

2:导出可以自动切换工作薄,默认一个工作薄2000行,测试发现5000条左右的数据导出可能失败并且导出时间较长,

切换工作薄可以提高成功率,并且方便阅读

3:导出需要传必要参数,返回值是保存的后的excel地址,链接即可下载

 <?php
/**
* 公共的导出类@author:zhaoyaei
* $column :导出的第一行标题
* $result :需要导出的结果集
* $path :导出文件的保存路径
* $sheet_num :每个工作薄的最大行数(可选)
* @return :保存的地址
*/
class Export{ public function __construct(){
//初始化类,引入相关类文件
include "PHPExcel.php";
include "PHPExcel/IOFactory.php";
} //导出设置
public function createxcel($column,$result,$path,$sheet_num = null){
//检查数据的合法性
if(empty($column) || empty($path) || $path == "" || empty($result)){
return false;
} //如果数据较大,则分薄导出
if(empty($sheet_num) || $sheet_num <= 0){
$sheet_num = 2000;
} $path = $this->check_encod("GBK",$path);
//创建PHPExcel实例
$objPHPExcel = new \PHPExcel();
//总数据行数和数据列数
$arr_num = count($result);
$field_count = count($column);
//工作薄数目,工作薄数量太多,可以调节煤业导出的数据条数减少工作薄数目
$get_num = ceil($arr_num / $sheet_num);
if($get_num > 20){
return false;
} //生成列信息
$ary = 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");
for($i = 1;$i <= $field_count; $i++){
$ary_info[$i] = $ary[$i/27].$ary[$i%27];
$fieldwidth[$i-1] = 20; //设置列宽默认是20
} //循环每个工作薄
for($sheet = 0;$sheet < $get_num; $sheet++){
//创建工作薄,设置起始工作薄
$objPHPExcel->createSheet($sheet);
$Sheet = $objPHPExcel->setActiveSheetIndex($sheet);
//设置工作薄样式
$i = 1;
foreach ($column as $key => $value){
//设置第一行的值
$Sheet->setCellValue($ary_info[$i] .'1', $value);
//设置第一行加粗
$objPHPExcel->getActiveSheet()->getStyle($ary_info[$i] .'1')->getFont()->setBold(true);
//设置行宽
$objPHPExcel->getActiveSheet()->getColumnDimension($ary_info[$i] )->setWidth($fieldwidth[$i-1]);
$i = $i + 1;
} //每个工作薄开始的行数
$hang_num = 2;
//本工作薄结束行数开始为0
$end_num = 0;
//start_num本工作薄开始行数
$start_num = $sheet*$sheet_num;
//计算出每次导出的开始行数和结束行数(多工作薄导出)
if($arr_num > ($start_num + $sheet_num)){
$end_num = $start_num + $sheet_num;
}else{
$end_num = $arr_num;
} //循环行数
for($i = $start_num; $i < $end_num; $i++){
//循环列数
for($j = 1;$j <= $field_count; $j++){
//写入数据
$Sheet->setCellValue($ary_info[$j].($hang_num)," ".$result[$i][$j]);
}
$hang_num++;
}
//设置sheet的名称
$objPHPExcel->getActiveSheet($sheet)->setTitle('sheet'.$sheet,$sheet);
//设置sheet的起始位置
$objPHPExcel->setActiveSheetIndex($sheet);
} //通过PHPExcel_IOFactory的写函数将上面数据写出来
$objWriter = \PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');
//设置时区
date_default_timezone_set("Asia/Shanghai");
//保存并返回保存路径
$objWriter->save($path);
return $this->check_encod("utf-8",$path);
} public function check_encod($encod,$string){
//判断字符编码
$encode = mb_detect_encoding($string, array("ASCII","UTF-8","GB2312","GBK","BIG5"));
if($encode != $encod){
$string = iconv($encode, $encod, $string);
}
return $string;
}
}
?>

php导出excel封装类的更多相关文章

  1. 022医疗项目-模块二:药品目录的导入导出-对XSSF导出excel类进行封装

    资源全部来源于传智播客. 好的架构师写的程序,就算给刚入门的新手看,新手一看就知道怎么去用.所以我们要对XSSF导出excel类进行封装.这是架构师的工作,但我们也要知道. 我们写一个封装类: 这个类 ...

  2. POI通过模板导出EXCEL文件

    一般的EXCEL导出使用POI先创建一个HSSFWorkbook,然后通过不断创建HSSFRow,HSSFCell后设置单元格内容便可以完成导出. 这次在项目中需要用到模板,导出的内容包括(1.模板中 ...

  3. C#使用Aspose.Cells导出Excel简单实现

    首先,需要添加引用Aspose.Cells.dll,官网下载地址:http://downloads.aspose.com/cells/net 将DataTable导出Xlsx格式的文件下载(网页输出) ...

  4. 利用poi导出Excel

    import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...

  5. [django]数据导出excel升级强化版(很强大!)

    不多说了,原理采用xlwt导出excel文件,所谓的强化版指的是实现在网页上选择一定条件导出对应的数据 之前我的博文出过这类文章,但只是实现导出数据,这次左思右想,再加上网上的搜索,终于找出方法实现条 ...

  6. NPOI导出Excel

    using System;using System.Collections.Generic;using System.Linq;using System.Text;#region NPOIusing ...

  7. ASP.NET Core 导入导出Excel xlsx 文件

    ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...

  8. asp.net DataTable导出Excel 自定义列名

    1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...

  9. Aspose.Cells导出Excel(1)

    利用Aspose.Cells导出excel 注意的问题 1.DataTable的处理 2.进行编码,便于中文名文件下载 3.别忘了Aspose.Cells.dll(可以自己在网上搜索) public ...

随机推荐

  1. 安装JBPM6运行环境(JBPM6学习之二)

    安装Eclipse插件成功后,需要配置JBPM6的运行环境: 1. 第一步先将下载的jbpm6目录中的“jbpm-6.0.1.Final-bin.zip”找到,并解压缩到D盘根目录备用. 2. 第二步 ...

  2. 他们在军训,我在搞 OI(Ending)

    Day 7 上午看看数学书,老师让我把导数相关的概念学了.这也没有多高大上,就是一坨公式需要背,什么 (a)' = 0 啦,什么 (xn)' = n·xn-1 啦,什么 sin'(x) = cos(x ...

  3. HTML 5 <input> placeholder 属性

    原文链接:http://www.w3school.com.cn/html5/att_input_placeholder.asp HTML 5 <input> placeholder 属性 ...

  4. VB中 ByRef与ByVal区别

    函数调用的参数传递有"值传递"和"引用传递"两种传递方式.如果采用"值传递",在函数内部改变了参数的值,主调程序的对应变量的值不会改变:如果 ...

  5. PowerDesigner V16.5 安装文件

    之前在网上找个假的,只能看,不能创建自己的DB; 或者 不能破解的,比较伤脑筋. 偶在这里提供一个 可长期使用的版本. PowerDesigner165_破解文件.rar    链接:http://p ...

  6. 使用html5 FileReader获取图片,并异步上传到服务器(不使用iframe)

    使用html5 FileReader获取图片,并异步上传到服务器(不使用iframe)   原理: 1.使用FileReader 读取图片的base64编码 2.使用ajax,把图片的base64编码 ...

  7. IntelliJ IDEA 常用快捷键列表及技巧大全

    IntelliJ Idea 常用快捷键列表 Alt+回车 导入包,自动修正Ctrl+N  查找类Ctrl+Shift+N 查找文件Ctrl+Alt+L  格式化代码Ctrl+Alt+O 优化导入的类和 ...

  8. How to take partial screenshot with Selenium WebDriver in python

    from selenium import webdriver from PIL import Image fox = webdriver.Firefox() fox.get('http://stack ...

  9. Appium+Robotframework实现Android应用的自动化测试-4:AppiumLibrary介绍和安装

    Appium是个好东东,Android,iOS都支持,并且居然RobotFramework也支持Appium了,这就是本文要介绍的AppiumLibrary. 通过前面的文章大家知道可以使用多种语言来 ...

  10. 22. javacript高级程序设计-高级技巧

    1. 高级技巧 1.1 函数 l 可以使用惰性载入函数,将任何分支推迟到第一个调用函数的时候 l 函数绑定可以让你创建始终在指定环境中运行的函数,同时函数柯里化可以让你创建已经填写了某些参数的函数 l ...