PHP Smarty生成EXCEL文档的代码
程序员文章站
2024-01-04 09:42:04
不过,跟据我的试验,如果你不删除一个地方,生成的文档用 excel 打开,是会报错的! 删除所有像这样的串: ss:expandedcolumncount="5" 就行了!...
不过,跟据我的试验,如果你不删除一个地方,生成的文档用 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下会发生错误。
删除所有像这样的串: 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下会发生错误。
推荐阅读
-
PHP Smarty生成EXCEL文档的代码
-
php编程实现获取excel文档内容的代码实例_PHP
-
php随机数代码:php生成随机数与随机字符串的例子
-
excel表格的35招必学秘技视频 php生成EXCEL的东东
-
php中生成随机密码的自定义函数代码
-
我们经常要处理一些以星期为单位的日期,以下的代码生成一个从当_PHP
-
PHP n个不重复的随机数生成代码_PHP教程
-
从零开始学YII2框架(五)快速生成代码工具 Gii 的使用,yii2gii_PHP教程
-
php生成指定频率和声音的音频文件(代码教程)
-
PHP用Smarty模板生成的html在IE里的点击没有反应(用bootstrap库了)