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 相关文章推荐
phpBB BBcode处理的漏洞
Oct 09 PHP
dedecms中常见问题修改方法总结
Mar 21 PHP
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
Jun 19 PHP
php-perl哈希算法实现(times33哈希算法)
Dec 30 PHP
一个PHP针对数字的加密解密类
Mar 20 PHP
PHP curl实现抓取302跳转后页面的示例
Jul 04 PHP
Laravel 5框架学习之环境与配置
Apr 08 PHP
PHP实现简单实用的分页类代码
Apr 08 PHP
YII视图整合kindeditor扩展的方法
Jul 13 PHP
微信公众号开发之通过接口删除菜单
Feb 20 PHP
php基于PDO实现功能强大的MYSQL封装类实例
Feb 27 PHP
Yii框架参数化查询中IN查询只能查询一个的解决方法
May 20 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数组函数序列之in_array() 查找数组值是否存在
2011/10/29 PHP
分享php多功能图片处理类
2016/05/15 PHP
PHP实现支持CURL字符串证书传输的方法
2019/03/23 PHP
laravel解决迁移文件一次删除创建字段报错的问题
2019/10/24 PHP
php解析非标准json、非规范json的方式实例
2020/12/10 PHP
JavaScript高级程序设计 客户端存储学习笔记
2011/09/10 Javascript
JS中的this变量的使用介绍
2013/10/21 Javascript
js中apply方法的使用详细解析
2013/11/04 Javascript
jquery $.fn $.fx是什么意思有什么用
2013/11/04 Javascript
js常用自定义公共函数汇总
2014/01/15 Javascript
javasript实现密码的隐藏与显示
2015/05/08 Javascript
jQuery mobile类库使用时加载导航历史的方法简介
2015/12/04 Javascript
jQuery过滤选择器用法示例
2016/09/12 Javascript
Bootstrap框架安装使用详解
2017/01/21 Javascript
基于javascript实现最简单选项卡切换
2017/02/01 Javascript
jquery.flot.js简单绘制折线图用法示例
2017/03/13 Javascript
JQuery实现table中tr上移下移的示例(超简单)
2018/01/08 jQuery
js实现列表向上无限滚动
2020/01/13 Javascript
Vue CLI3移动端适配(px2rem或postcss-plugin-px2rem)
2020/04/27 Javascript
python 实现堆排序算法代码
2012/06/05 Python
Python实现的批量修改文件后缀名操作示例
2018/12/07 Python
PyQt5下拉式复选框QComboCheckBox的实例
2019/06/25 Python
从0到1使用python开发一个半自动答题小程序的实现
2020/05/12 Python
使用css3绘制出各种几何图形
2016/08/17 HTML / CSS
详解CSS3:overflow属性
2020/11/17 HTML / CSS
阿迪达斯加拿大官网:Adidas加拿大
2016/08/25 全球购物
草莓网化妆品日本站:Strawberrynet日本
2017/10/20 全球购物
wedgwood加拿大官网:1759年成立的英国国宝级陶瓷餐具品牌
2018/07/17 全球购物
矫正人员思想汇报
2014/01/08 职场文书
军训考核自我鉴定
2014/02/13 职场文书
历史专业大学生职业生涯规划书
2014/03/13 职场文书
关于国庆节的演讲稿
2014/09/05 职场文书
四查四看整改措施
2014/09/19 职场文书
2015新年寄语大全
2014/12/08 职场文书
2015年实习单位评语
2015/03/25 职场文书
Python基础之元类详解
2021/04/29 Python