PHP Smarty生成EXCEL文檔的代碼
更新時間:2008年08月23日 08:28:41 作者:
PHP結(jié)合Smarty產(chǎn)生EXCEL文檔
1,首先在EXCEL (office 2003)里生成一個模板,然后存成 xml表格。
2,修改這個 xml 文件,做成 smarty 的模板。
3,然后,就是 綁定變量,輸出就行了。
不過,跟據(jù)我的試驗,如果你不刪除一個地方,生成的文檔用 excel 打開,是會報錯的!
刪除所有像這樣的串: ss:ExpandedColumnCount="5" 就行了!
示例:
隨便填點數(shù)據(jù),然后提交,會生成一份 xls 文件。
還有一個小問題沒有找出來,這個模板,只能有兩筆數(shù)據(jù),多了也不行,暈,還沒有找到要修改哪里呢。
另外,我開始是把 formValidate.php 和 report.php合在一起寫的,結(jié)果是沒有結(jié)果!
分開寫,就有結(jié)果了!
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下會發(fā)生錯誤。
刪除所有像這樣的串: ss:ExpandedColumnCount="5" 就行了!
示例:
隨便填點數(shù)據(jù),然后提交,會生成一份 xls 文件。
還有一個小問題沒有找出來,這個模板,只能有兩筆數(shù)據(jù),多了也不行,暈,還沒有找到要修改哪里呢。
另外,我開始是把 formValidate.php 和 report.php合在一起寫的,結(jié)果是沒有結(jié)果!
分開寫,就有結(jié)果了!
report.php
復(fù)制代碼 代碼如下:
<?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下會發(fā)生錯誤。
相關(guān)文章
YII2框架中ActiveDataProvider與GridView的配合使用操作示例
這篇文章主要介紹了YII2框架中ActiveDataProvider與GridView的配合使用操作,結(jié)合實例形式分析了YII2框架中ActiveDataProvider與GridView的功能及配合使用相關(guān)操作實現(xiàn)技巧,需要的朋友可以參考下2020-03-03
tp5.1 框架數(shù)據(jù)庫高級查詢技巧實例總結(jié)
這篇文章主要介紹了tp5.1 框架數(shù)據(jù)庫高級查詢技巧,結(jié)合實例形式總結(jié)分析了tp5.1 框架數(shù)據(jù)庫快捷查詢、區(qū)間查詢、批量查詢、閉包查詢等相關(guān)高級查詢使用技巧,需要的朋友可以參考下2020-05-05
php靜態(tài)成員方法和靜態(tài)的成員屬性的使用方法
這篇文章主要介紹了php靜態(tài)成員方法和靜態(tài)的成員屬性的使用方法的相關(guān)資料,希望通過本文能幫助到大家,讓大家使用的時候注意方法,需要的朋友可以參考下2017-10-10
PHP基于GD庫的縮略圖生成代碼(支持jpg,gif,png格式)
你可能會遇到這樣的問題,在用戶上傳了一張圖片后,得到這張圖片的縮略圖,PHP可以使用GD庫生成縮略圖,那么我們來探討下,如何才能生成高質(zhì)量的縮略圖呢?2014-06-06
Yii2框架實現(xiàn)數(shù)據(jù)庫常用操作總結(jié)
本篇文章主要介紹了Yii2框架實現(xiàn)數(shù)據(jù)庫常用操作總結(jié),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02

