所以我试图通过php将mysql表导出到csv文件。这是代码
<?php if (isset($_POST['exp'])) {
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename=data.csv');
$output = fopen('php://output', 'w');
fputcsv($output, array('User ID', 'User Name', 'Password'));
$con = mysqli_connect('localhost', 'root', 'pass', 'xyz');
$rows = mysqli_query($con, 'SELECT * FROM users');
while ($row = mysqli_fetch_assoc($rows)) {
fputcsv($output, $row);
}
fclose($output);
mysqli_close($con);
}
?>
<div>
<form action="#" method="post">
<input type="submit" value="Export" name="exp" />
</form>
</div>
一切都很好,但html部分也被转储到csv文件中。这是csv的屏幕截图
为什么会这样呢?我做错什么了吗?
您的页面继续加载超出PHP的范围。exit()
在IF语句的末尾添加,它将在此处停止运行。
<?php if (isset($_POST['exp'])) {
header('Content-Type: text/csv; charset=utf-8');
header('Content-Disposition: attachment; filename=data.csv');
$output = fopen('php://output', 'w');
fputcsv($output, array('User ID', 'User Name', 'Password'));
$con = mysqli_connect('localhost', 'root', 'pass', 'xyz');
$rows = mysqli_query($con, 'SELECT * FROM users');
while ($row = mysqli_fetch_assoc($rows)) {
fputcsv($output, $row);
}
fclose($output);
mysqli_close($con);
exit();
}
?>
<div>
<form action="#" method="post">
<input type="submit" value="Export" name="exp" />
</form>
</div>
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句