3

在我的网站中,我正在从 mysql 数据创建一个表,然后现在我想在表中添加一个导出按钮按钮,以便用户能够将数据下载为 CSV 文件。

为此,我编写了虚拟表单:

<form action="<?=$_SERVER['PHP_SELF'];?>" method="post">
    <input type="submit" name="submit" value="Click Me">
</form>

在 php 文件的顶部,我有:

if(isset($_POST['submit'])) {
    export();
}

在我的导出函数中,我有一些 mysql 的东西,我正在创建一个数组并将数据推入其中,然后:

$header = array('name', 'date', 'total', 'success', 'opens', 'clicks', 'success_rate', 'open_rate', 'CTO', 'CTR')
$fp = fopen('exportme2.csv', 'w');
fputcsv($fp, $header);

foreach ($data as $lines) {
        fputcsv($fp, $lines);
}
fclose($fp);

单击导出按钮后,我将拥有 exportme2.csv 文件,但它是空的!数据可能是错误的,所以不会有任何东西,但至少我应该有标题名称。

你能帮我解决这个问题吗?

谢谢。

4

3 回答 3

2

首先,改变

$fp = fopen('exportme2.csv', 'w');

$fp = fopen('exportme2.csv', 'a');

as'w' 截断文件,其中'a'创建或附加文件。

然后您应该使用flock()以确保两个不同的用户(线程)不要尝试同时写入文件:

if (!flock($fp, LOCK_EX)) {
    error_log('Cannot get lock!');
} else {
    fputcsv($fp, $header);

    foreach ($data as $lines) {
        fputcsv($fp, $lines);
    }
}

如果这不能解决问题,那么您的代码中有一个对我来说并不明显的错字。

于 2012-07-18T20:15:55.170 回答
1

这对我来说很好:

$header = array('name', 'date', 'total', 'success', 'opens', 'clicks', 'success_rate', 'open_rate', 'CTO', 'CTR');
$fp = fopen('exportme2.csv', 'w');
fputcsv($fp, $header);

/*foreach ($data as $lines) {
    fputcsv($fp, $lines);
}*/
fclose($fp);

您的上述脚本在 fclose 之前停止,因此它对您的文件进行了窃听……您应该在启用 E_ALL E_STRICT 的情况下进行开发!

于 2012-07-18T20:15:59.193 回答
0

它没有发布任何内容,因为它提交了页面,因此当页面刷新时,我的所有数组都变为空。

于 2012-07-18T20:22:51.093 回答