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 SQL防注入代码集合
Apr 25 PHP
php自动注册登录验证机制实现代码
Dec 20 PHP
PHP中最容易忘记的一些知识点总结
Apr 28 PHP
配置php网页显示各种语法错误
Sep 23 PHP
php选择排序法实现数组排序实例分析
Feb 16 PHP
PHP基于phpqrcode生成带LOGO图像的二维码实例
Jul 10 PHP
php实现计算百度地图坐标之间距离的方法
May 05 PHP
Yii2 ActiveRecord多表关联及多表关联搜索的实现
Jun 30 PHP
Yii2.0多文件上传实例说明
Jul 24 PHP
[原创]PHP实现字节数Byte转换为KB、MB、GB、TB的方法
Aug 31 PHP
PHP实现字符串的全排列详解
Apr 24 PHP
laravel数据库查询结果自动转数组修改实例
Feb 27 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正则校验用户名介绍
2008/07/19 PHP
使用PHP会话(Session)实现用户登陆功能
2013/06/29 PHP
删除html标签得到纯文本可处理嵌套的标签
2014/04/28 PHP
浅谈php安全性需要注意的几点事项
2014/07/17 PHP
PHP技术开发微信公众平台
2015/07/22 PHP
thinkphp项目如何自定义微信分享描述内容
2017/02/20 PHP
PHP的PDO错误与错误处理
2019/01/27 PHP
做网页的一些技巧
2007/02/01 Javascript
javascript之学会吝啬 精简代码
2010/04/25 Javascript
IE8 中使用加速器(Activities)
2010/05/14 Javascript
JqGrid web打印实现代码
2011/05/31 Javascript
javascript日期转换 时间戳转日期格式
2011/11/05 Javascript
javascript处理表单示例(javascript提交表单)
2014/04/28 Javascript
Dojo Javascript 编程规范 规范自己的JavaScript书写
2014/10/26 Javascript
JavaScript跨平台的开源框架NativeScript
2015/03/24 Javascript
javascript简单实现类似QQ头像弹出效果的方法
2015/08/03 Javascript
Python中比较特别的除法运算和幂运算介绍
2015/04/05 Python
初步介绍Python中的pydoc模块和distutils模块
2015/04/13 Python
Nginx搭建HTTPS服务器和强制使用HTTPS访问的方法
2015/08/16 Python
Python爬虫之正则表达式基本用法实例分析
2018/08/08 Python
selenium设置proxy、headers的方法(phantomjs、Chrome、Firefox)
2018/11/29 Python
学python安装的软件总结
2019/10/12 Python
在tensorflow中实现屏蔽输出的log信息
2020/02/04 Python
python with (as)语句实例详解
2020/02/04 Python
appium+python adb常用命令分享
2020/03/06 Python
python实现俄罗斯方块游戏(改进版)
2020/03/13 Python
django正续或者倒序查库实例
2020/05/19 Python
如何解决安装python3.6.1失败
2020/07/01 Python
do you have any Best Practice for testing
2016/06/04 面试题
电信营业员自我评价分享
2014/01/17 职场文书
聚美优品陈欧广告词
2014/03/14 职场文书
环保专项行动方案
2014/05/12 职场文书
安全责任书怎么写
2014/07/28 职场文书
百年校庆宣传标语口号
2015/12/26 职场文书
SQL实现LeetCode(176.第二高薪水)
2021/08/04 MySQL
Java 通过手写分布式雪花SnowFlake生成ID方法详解
2022/04/07 Java/Android