php导出excel封装类
因为实际情况的需要,导出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封装类的更多相关文章
- 022医疗项目-模块二:药品目录的导入导出-对XSSF导出excel类进行封装
资源全部来源于传智播客. 好的架构师写的程序,就算给刚入门的新手看,新手一看就知道怎么去用.所以我们要对XSSF导出excel类进行封装.这是架构师的工作,但我们也要知道. 我们写一个封装类: 这个类 ...
- POI通过模板导出EXCEL文件
一般的EXCEL导出使用POI先创建一个HSSFWorkbook,然后通过不断创建HSSFRow,HSSFCell后设置单元格内容便可以完成导出. 这次在项目中需要用到模板,导出的内容包括(1.模板中 ...
- C#使用Aspose.Cells导出Excel简单实现
首先,需要添加引用Aspose.Cells.dll,官网下载地址:http://downloads.aspose.com/cells/net 将DataTable导出Xlsx格式的文件下载(网页输出) ...
- 利用poi导出Excel
import java.lang.reflect.Field;import java.lang.reflect.InvocationTargetException;import java.lang.r ...
- [django]数据导出excel升级强化版(很强大!)
不多说了,原理采用xlwt导出excel文件,所谓的强化版指的是实现在网页上选择一定条件导出对应的数据 之前我的博文出过这类文章,但只是实现导出数据,这次左思右想,再加上网上的搜索,终于找出方法实现条 ...
- NPOI导出Excel
using System;using System.Collections.Generic;using System.Linq;using System.Text;#region NPOIusing ...
- ASP.NET Core 导入导出Excel xlsx 文件
ASP.NET Core 使用EPPlus.Core导入导出Excel xlsx 文件,EPPlus.Core支持Excel 2007/2010 xlsx文件导入导出,可以运行在Windows, Li ...
- asp.net DataTable导出Excel 自定义列名
1.添加引用NPOI.dll 2.cs文件头部添加 using NPOI.HSSF.UserModel; using NPOI.SS.UserModel; using System.IO; 3.代码如 ...
- Aspose.Cells导出Excel(1)
利用Aspose.Cells导出excel 注意的问题 1.DataTable的处理 2.进行编码,便于中文名文件下载 3.别忘了Aspose.Cells.dll(可以自己在网上搜索) public ...
随机推荐
- iOS开发——UI进阶篇(十三)UITabBarController简单使用,qq主流框架
一.UITabBarController简单使用 // 程序加载完毕 - (BOOL)application:(UIApplication *)application didFinishLaunchi ...
- BZOJ3277——串
0.题意:给定你n个字符串,询问每个字符串有多少子串(不包括空串)是所有n个字符串中至少k个字符串的子串(注意包括本身). 1.分析:这个题我问了吴大爷做法 首先建立后缀自动机,然后利用离线搞出每一个 ...
- Unity3D客户端和Java服务端使用Protobuf
转自:http://blog.csdn.net/kakashi8841/article/details/17334493 前几天有位网友问我关于Unity3D里面使用Protobuf的方法,一时有事拖 ...
- Mysql报错Fatal error: Can't open and lock privilege tables: Table 'mysql.host' doesn't exist
安装mysql后,启动时候没有启动成功,查看了下日志报错如下:---------------------------------------------1 可以:初始化mysql:mysql_in ...
- ubuntu查看端口占用
查看端口号 sudo netstat -ltnp | 结束进程 sudo kill pid
- Thinkphp .htaccess 与 httpd.ini文件重定向转换问题
.htaccess 文件内容 RewriteEngine OnRewriteCond %{REQUEST_FILENAME} !-dRewriteCond %{REQUEST_FILENAME} !- ...
- C# 毕业证书打印《五》
对鼠标操作Label的方法 #region //定义一个枚举类型,描述光标状态 private enum EnumMousePointPosition { #region MouseSizeNone ...
- Java 中常用缓存Cache机制的实现《二》
所谓缓存,就是将程序或系统经常要调用的对象存在内存中,一遍其使用时可以快速调用,不必再去创建新的重复的实例.这样做可以减少系统开销,提高系统效率. AD: Cache 所谓缓存,就是将程序或系统经常要 ...
- js 为label标签和div标签赋值
<label id="ttile"></label> document.getElementById('ttile').innerText="&q ...
- 一个静态的HTML页面用jquery ajax登录到sharepoint页面
$.ajax({ type: "get", url: "http://", d ...