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来自动调用不同服务器上的flash
Oct 09 PHP
php 代码优化之经典示例
Mar 24 PHP
PHP生成随机用户名和密码的实现代码
Feb 27 PHP
php实例分享之通过递归实现删除目录下的所有文件详解
May 15 PHP
浅谈PHP中Stream(流)
Jun 08 PHP
Smarty foreach控制循环次数的一些方法
Jul 01 PHP
php简单创建zip压缩文件的方法
Apr 30 PHP
Yii2中事务的使用实例代码详解
Sep 07 PHP
PHP获取文本框、密码域、按钮的值实例代码
Apr 19 PHP
实例讲解php将字符串输出到HTML
Jan 27 PHP
YII框架模块化处理操作示例
Apr 26 PHP
php实现简单的守护进程创建、开启与关闭操作
Aug 13 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
基于empty函数的判断详解
2013/06/17 PHP
php求两个目录的相对路径示例(php获取相对路径)
2014/03/27 PHP
zen cart实现订单中增加paypal中预留电话的方法
2016/07/12 PHP
ThinkPHP5 的简单搭建和使用详解
2018/11/15 PHP
laravel 解决多库下的DB::transaction()事务失效问题
2019/10/21 PHP
IE6下CSS图片缓存问题解决方法
2010/12/09 Javascript
javascript中数组的冒泡排序使用示例
2013/12/18 Javascript
js中的for如何实现foreach中的遍历
2014/05/31 Javascript
JavaScript实现找出字符串中第一个不重复的字符
2014/09/03 Javascript
详谈javascript中DOM的基本属性
2015/02/26 Javascript
运行Node.js的IIS扩展iisnode安装配置笔记
2015/03/02 Javascript
javascript获取系统当前时间的方法
2015/11/19 Javascript
jquery动态创建div与input的实例代码
2016/10/12 Javascript
jquery.flot.js简单绘制折线图用法示例
2017/03/13 Javascript
详解用vue编写弹出框组件
2017/07/04 Javascript
vue项目中api接口管理总结
2018/04/20 Javascript
Vue.js实现数据响应的方法
2018/08/13 Javascript
利用Dectorator分模块存储Vuex状态的实现
2019/02/05 Javascript
python+Django+apache的配置方法详解
2016/06/01 Python
python数据清洗系列之字符串处理详解
2017/02/12 Python
python3 读取Excel表格中的数据
2018/10/16 Python
用Anaconda安装本地python包的方法及路径问题(图文)
2019/07/16 Python
Python中的上下文管理器相关知识详解
2019/09/19 Python
numpy:np.newaxis 实现将行向量转换成列向量
2019/11/30 Python
如何理解python中数字列表
2020/05/29 Python
Python爬虫抓取论坛关键字过程解析
2020/10/19 Python
详解matplotlib绘图样式(style)初探
2021/02/03 Python
深入浅析HTML5中的article和section的区别
2018/05/15 HTML / CSS
找到不普通的东西:Bonanza
2016/10/20 全球购物
如何向接受结构参数的函数传入常数值
2016/02/17 面试题
让生命充满爱演讲稿
2014/05/10 职场文书
党员干部廉政承诺书
2015/04/28 职场文书
2016猴年春节慰问信
2015/11/30 职场文书
利用Python判断你的密码难度等级
2021/06/02 Python
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
Oracle查看表空间使用率以及爆满解决方案详解
2022/07/23 Oracle