当前位置: 首页 > 图文教程 > 网络编程 > PHP > PHP Smarty生成EXCEL文档的代码

PHP
IIS+mysql+php学习
PEAR MDB 数据库抽象层 ?? 一次编写?随处运行
数据库设计技巧(二)
数据库设计技巧(三)
PHP中通过ADO调用Access数据库
从 MySQL 导入导出大量数据的程序实现方法
MySQL中修改密码及访问限制设置详解
数据库设计范式
MySQL 查询中的分页思路的优化
Adodb 官方介绍
PHP中 ADOdb 类库介绍(二)
PHP中 ADOdb 类库介绍(一)
MySQL中各种字段的取值范围
数据库设计技巧(一)
为数据库建立索引(一)
为数据库建立索引(二)
用 PHP 实现 XML 备份 Mysql 数据库
mysql常见出错代码
浅谈php+mysql身份验证的方法
apache服务器配置全攻略

PHP Smarty生成EXCEL文档的代码


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-13   浏览: 123 ::
收藏到网摘: n/a

PHP结合Smarty产生EXCEL文档 1,首先在EXCEL (office 2003)里生成一个模板,然后存成 xml表格。 2,修改这个 xml 文件,做成 smarty 的模板。 3,然后,就是 绑定变量,输出就行了。 不过,跟据我的试验,如果你不删除一个地方,生成的文档用 excel 打开,是会报错的!
删除所有像这样的串: ss:ExpandedColumnCount="5" 就行了!
示例:
随便填点数据,然后提交,会生成一份 xls 文件。
还有一个小问题没有找出来,这个模板,只能有两笔数据,多了也不行,晕,还没有找到要修改哪里呢。
另外,我开始是把 formValidate.php 和 report.php合在一起写的,结果是没有结果!
分开写,就有结果了!
report.php
复制代码 代码如下:

<?php
include '../common.inc.php';
$token = $_POST['token'];
if(GToken::isToken($token,'REPORT')){
$names = $_POST['name'];
$birthdays = $_POST['birthday'];
$phones = $_POST['phone'];
$sexs = $_POST['sex'];
$emails = $_POST['email'];
$scoreAs = $_POST['scoreA'];
$scoreBs = $_POST['scoreB'];
$scoreCs = $_POST['scoreC'];
$list = array();
$score = array();
for($i=0;$i<sizeof($names);$i++){
$arr = array(
'name' => $names[$i],
'sexs' => $sexs[$i],
'birthday' => $birthdays[$i],
'email' => $emails[$i],
'phone' => $phones[$i]
);
array_push($list,$arr);
unset($arr);
$arr = array(
'name' => $names[$i],
'scoreA' => $scoreAs[$i],
'scoreB' => $scoreBs[$i],
'scoreC' => $scoreCs[$i]
);
array_push($score,$arr);
unset($arr);
}
include '../lib/smarty/Smarty.class.php';
$gmt = GSmarty::getInstance('test');
$gmt->assign_by_ref("list",$list);
$gmt->assign_by_ref('score',$score);
header("Cache-Control: public");
header('content-type:application/vnd.ms-excel');
header("Content-Disposition:attachment; filename=report.xls");
$gmt->display('report');
}
?>

header("Cache-Control: public");
这一定要加,不然的话,在IE下会发生错误。