PHP Smarty生成EXCEL文档的代码
前端之家收集整理的这篇文章主要介绍了
PHP Smarty生成EXCEL文档的代码,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
不过,跟据我的试验,如果你不删除一个地方,生成的文档用 excel 打开,是会报错的! 删除所有像这样的串: ss:ExpandedColumnCount="5" 就行了! 示例: 随便填点数据,然后提交,会生成一份 xls 文件。 还有一个小问题没有找出来,这个模板,只能有两笔数据,多了也不行,晕,还没有找到要修改哪里呢。 另外,我开始是把 formValidate.PHP 和 report.PHP合在一起写的,结果是没有结果!
分开写,就有结果了! report.PHP
<div class="codetitle">@L_404_0@ 代码如下:
<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');
}
?>