如何从 PHP 脚本将 SQLite 文件导出为 Excel?
我目前使用以下代码将表和数据导出为纯 HTML 表:
$dbh = new PDO('sqlite:' . $path . "/" . $lang . "/" . $dbname . ".sqlite");
$sql = "SELECT tbl_name FROM sqlite_master WHERE type='table';";
$stmt = $dbh->prepare($sql, array(PDO::ATTR_CURSOR, PDO::CURSOR_SCROLL));
$stmt->execute();
while ($row = $stmt->fetch(PDO::FETCH_ASSOC, PDO::FETCH_ORI_NEXT)) {
$sql = "SELECT * FROM " . $row['tbl_name'];
$sub_stmt = $dbh->prepare($sql, array(PDO::ATTR_CURSOR, PDO::CURSOR_SCROLL));
$sub_stmt->execute();
echo "<br><br><table border=1><thead>". $row['tbl_name'] ."</thead><tbody>";
while ($sub_row = $sub_stmt->fetch(PDO::FETCH_ASSOC, PDO::FETCH_ORI_NEXT)) {
foreach ($sub_row as $key => $value) {
$titles .= "<td>" . $key . "</td>";
$sub_row_table[] = "<td>" . $sub_row[$key] . "</td>";
}
if(!$titlesPrinted) {
echo "<tr>" . $titles . "</tr>";
$titlesPrinted = true;
}
echo "<tr>";
foreach($sub_row_table as $value) {
echo $value;
}
echo "</tr>";
}
echo "</tbody></table>";
}
$dbh = null;
但是,如果 sqlite 表有大量数据,则效果不佳,页面需要一段时间才能加载所有内容。理想情况下,我更愿意创建链接来下载 Excel 工作表(或者可以将所有工作表都导出到一个 Excel 工作簿文件中,并将所有工作表作为每个表格?),或者至少链接到弹出/显示表格而不是用完很多回显到用户屏幕的资源。
编辑:
忘了提到我的 sqlite 数据包含一些使用 HTML 的列,并且许多数据使用重音符号,例如:è、é、ê、à、ä 等。