作者chrisQQ (ChrisLiu)
看板PHP
标题Re: [请益] PHP如何汇出多个EXCEL档?
时间Tue Aug 17 13:12:18 2010
※ 引述《TaiKeDa (科科)》之铭言:
: 请照着箭头走流程
: Client Server
: 我要下载 → 开始产生档案
: ↓
: 存入资料夹
: ↓
: 开始下载 ← 压缩成单一档案
: ↓
: 解压缩
我原本也以为是要作成这样↑↑↑↑↑…既然都写了,那就乾脆骗骗 P 币…
1. 按[按钮]送出所需要的资料给後端 php
2. 後端 php 根据你送出的资料,产生 n 个档案到该资料夹底下
3. 透过 exec / system function 执行 tar / zip 资料夹
4. 压缩完得到档案之後,送出 header, readfile 让使用者直接下载
後端 php
<?php
// get something from previous page
$_REQUEST / $_GET / $_POST
foreach / for ($i=0;$i<=$size;$i++)
{
// 读取你的 csv 资料
$csv = some_function_load_csv_data();
$fp = fopen("data/file{$i}.csv", "w+");
fwrite($fp, $csv);
fclose($fp);
}
// 压缩资料夹
exec('tar -zcvf /somepath/filename.tgz /path/to/your/folder/data');
// 送出下载的 header 与指定 file name
header('Content-Disposition: attachment; filename="cvs.tgz"');
// 读档
readfile('/somepath/filename.tgz');
?>
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 203.145.202.67
1F:推 TaiKeDa:档案名称或资料夹名称尽量要避免重复 :p 08/17 13:17
2F:→ kosjason:我不得不说 提供真相 真的有差 08/17 13:17
3F:→ TaiKeDa:不然多人同时使用可能会出现问题 ... XD 08/17 13:17
4F:推 savenckugo:推推推~ 08/17 13:18
5F:推 TaiKeDa:推 chrisQQ 也推原PO XD 08/17 13:22
6F:→ chrisQQ:所以要从前一页取得资讯罗~再加在档名中,如果档名一样 08/17 13:28
7F:→ chrisQQ:代表要压缩的资料一样,那就直接跳过产生与压缩的步骤 08/17 13:28
8F:→ chrisQQ:直接丢档案~ 不过这只是精简版啦… 就意思意思… 08/17 13:29
9F:→ chrisQQ:不过我没点开真相… ˇˇ 08/17 13:29
10F:推 TaiKeDa:我知道是精简版,只是提醒一下原PO这样 XD 08/17 13:35
11F:→ chrisQQ:虽然我觉得原po可能不是要走这个箭头… 08/17 13:36
12F:推 nclovegc:不好意思 想问一下 假设这样产生 那n个档案产生後会消失 08/17 13:40
13F:→ nclovegc:吗?其实我就是直接卡在产生n个档案到资料夹这段... 08/17 13:40
14F:→ nclovegc:应该这麽说 我的CSV档案也是由PHP产生出来的 一开始没有 08/17 13:41
15F:推 TaiKeDa:那就看 chrisQQ 的 foreach / for ... 那段 08/17 13:41
16F:→ chrisQQ:不会消失,如果你想要他消失,可以在用 exec('rm data/*') 08/17 13:42
17F:推 SmallBeeWayn:有正妹真相大家都回的好认真.... 08/17 13:42
18F:→ chrisQQ:只是刚好最近的问题都不怎麽好玩… 是巧合@@ 08/17 13:43
19F:→ nclovegc:exec()函数需要下载什麽吗?还是PHP就可以直接用了@@? 08/17 13:43
20F:→ chrisQQ:不用,exec 是 php 内建。话说,你的 php 主机环境是? 08/17 13:44
21F:→ chrisQQ:unix-like or windows ? 08/17 13:44
23F:→ chrisQQ:我的 code 是以在 unix-like os 下的环境写的~ 08/17 13:45
24F:推 TaiKeDa:删除也可以用 unlink(), rm() 08/17 13:49
25F:推 nclovegc:我是windows 08/17 14:01
26F:→ chrisQQ:unlink 只能删除单一档案吧~ 当然是 rm * 最快 XD 08/17 14:01
27F:→ chrisQQ:windows 的话用 7z 好像比较方便,他有 console 版 08/17 14:02
28F:推 nclovegc:所以我必须要先设一个tmp资料夹 专门用来存这些档案吗? 08/17 14:03
29F:→ chrisQQ:是的~ 08/17 14:59
30F:推 nclovegc:写出来了 真的很感谢chrisQQ 版上果然神手超多XDD 08/17 15:09