微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PHP Smarty生成EXCEL文档的代码

不过,跟据我的试验,如果你不删除一个地方,生成的文档用 excel 打开,是会报错的! 删除所有像这样的串: ss:ExpandedColumnCount="5" 就行了! 示例: 随便填点数据,然后提交,会生成一份 xls 文件。 还有一个小问题没有找出来,这个模板,只能有两笔数据,多了也不行,晕,还没有找到要修改哪里呢。 另外,我开始是把 formValidate.PHP 和 report.PHP合在一起写的,结果是没有结果!
分开写,就有结果了! report.PHP
<div class="codetitle"><a style="CURSOR: pointer" data="16177" class="copybut" id="copybut16177" onclick="doCopy('code16177')"> 代码如下:

<div class="codebody" id="code16177">
<?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下会发生错误

原文地址:https://www.jb51.cc/php/29518.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐