thinkphp中导出二维数组到Excel

1.解决时间长度导致EXCEL出现###问题

2.解决长数值型 带来的科学记数法导出问题 订单号不再变为科学记数法 而是直接字符串类型

代码如下:

<?php
/**
* Author lizhaoyao
* Add_Time:2015-08-26
* [php_excel_export 用户导出Excel]
* @param array $data [含有表头的数组]
* @param string $file_name [要保存的文件名]
* @param string $sheet_name [工作表名称]
* @return [type] [返回Excel]
*/
function php_excel_export($data=array(),$file_name='',$sheet_name='导出记录')
{
if($file_name==""){$file_name=time();}//如果没有给名称 默认为当前时间戳
Vendor('Classes.PHPExcel');//导入扩展类
$objPHPExcel = new PHPExcel();//实例化PHPExcel
$data_key=array_keys($data);//取出二维数组的第一个元素
$keys_list=array_keys($data[$data_key[0]]);//取出二维数组第一个数组的所有key
//为什么这么做 为什么不用$data[0]? 因为该方法未知用户传入的data是何种数组 如果是关联数组 $data[0]将失效且报警告
/*以下就是对处理Excel里的数据, 横着取数据,主要是这一步,其他基本都不要改*/
foreach($data as $k => $v)
{
$num=$k+1;//定义起始符
$middle_obj=$objPHPExcel->setActiveSheetIndex(0);//获取第一个工作表
$start_column='A';//定义起始列为A
foreach ($keys_list as $key => $value)
{
$objPHPExcel->getActiveSheet()->setCellValueExplicit($start_column.$num, $v[$value],PHPExcel_Cell_DataType::TYPE_STRING);//循环着给第几列赋值 并把长数值型变为文本型输出 解决导出形成科学记数法的瑕疵
//在excel中 列是以 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 AA AB AC AD AE AF……这样的形式增加的
//而字符串的增加正好符合这一规律 这也意味着 我们可以用字符串的自增来当作列
$objPHPExcel->getActiveSheet()->getColumnDimension($start_column)->setWidth(280);//设置每列宽度为280
$start_column++;//将列自增
}
}
$objPHPExcel->getActiveSheet()->setTitle($sheet_name);//设置sheet工作表名称
$objPHPExcel->setActiveSheetIndex(0);//设置表头
header('Content-Type: application/vnd.ms-excel');//输出头信息
header('Content-Disposition: attachment;filename="'.$file_name.'.xls"');//设置xls文件名称
header('Cache-Control: max-age=0');
$objWriter = PHPExcel_IOFactory::createWriter($objPHPExcel, 'Excel5');//创建输出
$objWriter->save('php://output');exit();//保存输出到下载
}
?>

此方法用到字符串加加的形式 入A++变为B Z++变为AA的原理 需要深刻理解字符串自增才行

thinkphp中使用PHPEXCEL导出数据的更多相关文章

  1. thinkphp中使用PHPEXCEL导入数据

    导入方法比较简单 但必须考虑到Excel本身单元格格式问题 例如以0开头的字符串读出来被去掉了前导0 成为float型而丢失一位 必须进行处理 <?php /** * Author lizhao ...

  2. php利用phpexcel导出数据

    php中利用phpexcel导出数据的实现代码.对phpexcel类库不熟悉的朋友,可以阅读下<phpexcel中文帮助手册>中的内容,具体实例大家可以phpexcel快速开发指南中的相关 ...

  3. Thinkphp解决phpExcel导出数据量大导致内存溢出

    工作需要导出几万的数据量.操作比较频繁.之前数据在七八千是数据导出很慢.phpExcel是方便但是性能一般.现在改为使用csv导出数据:可以缓解内存压力,一次导出两三万是没问题的.当然服务器内存给力, ...

  4. 基于ThinkPHP开发的PHPExcel导出

    首先我们需要去PHPExcel官网下载开源包 下载好了以后只需要把里面的classes文件夹解压出来就可以用了! 在ThinkPHP中,文件的命名空间还是很重要的,我试着按照其他的第三方命名写name ...

  5. phpexcel导出数据 出现Formula Error的解决方案

    phpexcel导出数据报错 Uncaught exception 'Exception' with message 'Sheet1!A1364 -> Formula Error: Unexpe ...

  6. php 使用PHPExcel 导出数据为Excel

    <?php require_once 'PHPExcel/Classes/PHPExcel.php'; /** * 导出数据为Excel * @param array $fieldArr 标题数 ...

  7. PHPExcel 导出数据(xls或xlsx)- 助手类(函数)

    本文链接:https://www.cnblogs.com/tujia/p/11358096.html 说明:简单好用的导出助手,轻松导出数据到 excel !! 使用示例: Example: Exce ...

  8. PHP:引用PhpExcel导出数据到excel表格

    我使用的是tp3.2框架(下载地址:http://www.thinkphp.cn/topic/38123.html) 1.首先要下载PhpExcel类库,放在如下图目录下 2.调用方法 public ...

  9. Yii框架中使用PHPExcel导出Excel文件

    最近在研究PHP的Yii框架,很喜欢,碰到导出Excel的问题,研究了一下,就有了下面的方法: 1.首先在config\main.php中添加对PHPExcel的引用,我的方式是这样: 1 2 3 4 ...

随机推荐

  1. android入门到熟练(二)----活动

    1.活动创建对于每一个后端java类(继承至Activity或者ActionBarActivity)代码都有一个方法需要被重写[onCreate], 在此方法中可以加载界面资源文件或者绑定元素事件. ...

  2. jquery.cycle.js简单用法实例

    样式: a{text-decoration: none;} *{;;} /*容器设置*/ .player { width:216px; height:248px; background:url(htt ...

  3. Java:对象的序列化

    一.对象序列化机制 序列化机制允许将实现序列化的Java对象转换为字节序列,这些字节序列可以被保存在磁盘上或通过网络传输,以备以后重新恢复原来的对象: 序列化机制使得对象可以脱离程序的运行而独立存在: ...

  4. 基于SAE+CodeIgniter3.0+管理端angularjs+前台amazeui的多用户博客系统V1.0--系统设计(一)

    开发环境: 服务器系统:CentOS-6.x web服务器:Apache-2.2.x php版本:PHP-5.3.x 开发工具:sublime text 3 ,谷歌浏览器 数据库查询工具:phpmya ...

  5. laravel学习前期遇到的小知识点(1)

    1. 目前我用的laravel 5.2.36版本web中间件成为全局中间件(不知道从5.2.26以上就改变了还是怎样,没有深究),也就是之前的版本路由里默认会有一个Route::group的web中间 ...

  6. Cinder-1 TinderBox

    Cinder:http://libcinder.org/,当前版本是0.8.5,代码托管位置:https://github.com/cinder/Cinder.git 下载Cinder之后,其目录结构 ...

  7. Opencv实现的简易绘图工具

    第一次写博,还是个菜鸟.最近开始学习Opencv,试着写了个简易的绘图工具(目前只写了画线和橡皮擦部分,画其它图形还有待往里添加),也算是记录自己的学习之路. #include "stdaf ...

  8. 机务UI设计小节

    1.CSS样式 .header { background-color:#7A8692; color:White; height:30px; font-size:16px; width:100%; li ...

  9. 《深入剖析Tomcat》阅读(一)

    第一章 一个简单的Web服务器 该应用程序仅接受位于指定目录的静态资源的请求,如HTML文件和图像文件.它也可以将传入的HTTP请求字节流显示到控制台上.但是,它并不发送任何头信息到浏览器,如日期或者 ...

  10. 如何打造一款五星级的 APP ?

    移动互联网大潮来袭!据统计,2015 年平均每天有 1000 个新的应用上架,而这些应用的现状可以说是鱼龙混杂,同是每个人的眼光.品味.意识和利益都不同,因此每人眼中的应用也是不同的.在巨大的市场竞争 ...