php中导出数据到excel时数字变为科学计数的解决方法


Posted in PHP onFebruary 03, 2013

在数据导出到excel时数字格式不对,一般分为以下两种情况。

1、excel单元格设置长度不够

解决方法:

//在excel.php文件中 
$objActSheet = $objPHPExcel->getActiveSheet(); 
// 设置 栏目名称 
$objActSheet->setCellValue("b1", "卡号"); 
// 设置列的宽度 
$objActSheet->getColumnDimension('b')->setWidth(20);//改变此处设置的长度数值

2、字符被excel理解成数字了,一般就是把那个字段设置成文本 或者想办法加入一些空格一类的。
解决方法:

//添加数据处,主要是把要显示数据以chunk_split()函数处理以下,此函数的具体用法可以自己查看 
$objActSheet->setCellValue ( "b$i", chunk_split("123456789 ",4," ") );//当然,如果不想让用户看到数字间有空格,那就把要分割的字段值设大一些,如例子中的4设为大于等于9的即可。

我导出EXcel的主要代码的前面部分:

<? 
if(count($data)>40000){ 
$filename_type='csv'; 
}else{ 
$filename_type='xls'; 
} 
header("Content-Type: application/vnd.ms-excel"); 
Header("Accept-Ranges:bytes"); 
Header("Content-Disposition:attachment;filename=".$filename.".".$filename_type); //$filename导出的文件名 
header("Pragma: no-cache"); 
header("Expires: 0"); 
if($filename_type=='xls'){ 
echo '<html xmlns:o="urn:schemas-microsoft-com:office:office" 
xmlns:x="urn:schemas-microsoft-com:office:excel" 
xmlns="http://www.w3.org/TR/REC-html40"> 
<head> 
<meta http-equiv="expires" content="Mon, 06 Jan 1999 00:00:01 GMT"> 
<meta http-equiv=Content-Type content="text/html; charset=gb2312"> 
<!--[if gte mso 9]><xml> 
<x:ExcelWorkbook> 
<x:ExcelWorksheets> 
<x:ExcelWorksheet> 
<x:Name></x:Name> 
<x:WorksheetOptions> 
<x:DisplayGridlines/> 
</x:WorksheetOptions> 
</x:ExcelWorksheet> 
</x:ExcelWorksheets> 
</x:ExcelWorkbook> 
</xml><![endif]--> </head>'; 
}

后面就是以<table><tr><td></td></tr></table>的格式输出数据

查了大半天终于查到了一点有用的资料,现在摘抄如下:

“首先,我们了解一下excel从web页面上导出的原理。当我们把这些数据发送到客户端时,我们想让客户端程序(浏览器)以excel的格式读取它,所以把mime类型设为:application/vnd.ms-excel,当excel读取文件时会以每个cell的格式呈现数据,如果cell没有规定的格式,则excel会以默认的格式去呈现该cell的数据。这样就给我们提供了自定义数据格式的空间,当然我们必须使用excel支持的格式。下面就列出常用的一些格式:
1) 文本:vnd.ms-excel.numberformat:@
2) 日期:vnd.ms-excel.numberformat:yyyy/mm/dd
3) 数字:vnd.ms-excel.numberformat:#,##0.00
4) 货币:vnd.ms-excel.numberformat:¥#,##0.00
5) 百分比:vnd.ms-excel.numberformat: #0.00%
这些格式你也可以自定义,比如年月你可以定义为:yy-mm等等。那么知道了这些格式,怎么去把这些格式添加到cell中呢?很简单,我们只需要把样式添加到对应的标签对(即闭合标签)即可。如<td></td>,给标签对<td></td>添加样式,如下: <td style="vnd.ms-excel.numberformat:@">410522198402161833</td>
同样,我们也可以给<div></div>添加样式,也可以给<tr></tr>,<table></table>添加样式;当我们在父标签对和子标签对都添加样式时,数据会以哪一个样式呈现呢?经过测试,会以离数据最近的样式呈现.

PHP 相关文章推荐
php 时间计算问题小结
Jan 04 PHP
javascript 小型动画组件与实现代码
Jun 02 PHP
php 删除一个数组中的某个值.兼容多维数组!
Feb 18 PHP
强烈声明: 不要使用(include/require)_once
Jun 06 PHP
php stream_get_meta_data返回值
Sep 29 PHP
php将mysql数据库整库导出生成sql文件的具体实现
Jan 08 PHP
php获取淘宝分类id示例
Jan 16 PHP
php导出生成word的方法
Dec 25 PHP
PHP魔术方法使用方法汇总
Feb 14 PHP
php实现按天数、星期、月份查询的搜索框
May 02 PHP
Laravel框架实现的记录SQL日志功能示例
Jun 19 PHP
如何用PHP websocket实现网页实时聊天
May 26 PHP
php中删除字符串中最先出现某个字符的实现代码
Feb 03 #PHP
php数组去重的函数代码
Feb 03 #PHP
php中使用临时表查询数据的一个例子
Feb 03 #PHP
PHP应用JSON技巧讲解
Feb 03 #PHP
set_include_path和get_include_path使用及注意事项
Feb 02 #PHP
php代码中使用换行及(\n或\r\n和br)的应用
Feb 02 #PHP
PHP常用特殊运算符号和函数总结(php新手入门必看)
Feb 02 #PHP
You might like
PHP安装全攻略:APACHE
2006/10/09 PHP
php将数据库中所有内容生成静态html文档的代码
2010/04/12 PHP
在PHP中运行Linux命令并启动SSH服务的例子
2014/06/12 PHP
php中magic_quotes_gpc对unserialize的影响分析
2014/12/16 PHP
Yii2框架BootStrap样式的深入理解
2016/11/07 PHP
PHP读取Excel类文件
2017/05/15 PHP
浅谈Laravel POST,PUT,PATCH 路由的区别
2019/10/15 PHP
Javascript 学习书 推荐
2009/06/13 Javascript
jQuery初学:find()方法及children方法的区别分析
2011/01/31 Javascript
js预载入和JavaScript Image()对象使用介绍
2011/08/28 Javascript
js调用浏览器打印模块实现点击按钮触发自定义函数
2014/03/21 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
2015/08/25 Javascript
JS实现浏览器状态栏显示时间的方法
2015/10/27 Javascript
js实现兼容IE、Firefox的图片缩放代码
2015/12/08 Javascript
VueJS全面解析
2016/11/10 Javascript
vue 计时器组件的实现代码
2017/09/14 Javascript
vue checkbox 全选 数据的绑定及获取和计算方法
2018/02/09 Javascript
JS实现同一DOM元素上onClick事件与onDblClick事件并存的解决方法
2018/06/07 Javascript
Vue 动态组件components和v-once指令的实现
2019/08/30 Javascript
JavaScript 作用域实例分析
2019/10/02 Javascript
vue下的@change事件的实现
2019/10/25 Javascript
Vue使用vue-draggable 插件在不同列表之间拖拽功能
2020/03/12 Javascript
为python设置socket代理的方法
2015/01/14 Python
python实现决策树C4.5算法详解(在ID3基础上改进)
2017/05/31 Python
Pandas中Series和DataFrame的索引实现
2019/06/27 Python
详解CSS3 弹性布局快速入门
2019/06/06 HTML / CSS
美国宠物商店:Wag.com
2016/10/25 全球购物
亚历山大·王官网:Alexander Wang
2017/06/23 全球购物
公务员培训心得体会
2013/12/28 职场文书
基层工作经历证明
2014/01/13 职场文书
岗位廉洁从业承诺书
2014/03/28 职场文书
《二泉映月》教学反思
2014/04/15 职场文书
会议欢迎标语
2014/06/30 职场文书
优秀员工推荐材料
2014/12/20 职场文书
Python图像处理之图像拼接
2021/04/28 Python
SpringBoot+VUE实现数据表格的实战
2021/08/02 Java/Android