【发布时间】:2021-12-19 00:20:14
【问题描述】:
这是我的 PHP 代码
<?php
require_once 'd:\xampp\htdocs\bpr\pdo_db.php';
$sql = "Select ID,FULL_NAMe,AGE from TRIAL";
$csv = get_csv_string($dbh, $sql);
echo "<script> var_csv='" . $csv . "' </script>";
function get_csv_string($dbh, $sql)
{
try
{
$result = $dbh->query($sql);
//return only the first row (we only need field names)
$row = $result->fetch(PDO::FETCH_ASSOC);
if ($row == null) {
return "No Data";
}
$f = fopen('php://memory', 'r+');
foreach ($row as $field => $value) {
if (fputcsv($f, $field) === false) {
return false;
}
}
//second query gets the data
$data = $dbh->query($sql);
$data->setFetchMode(PDO::FETCH_ASSOC);
foreach ($data as $row) {
if (fputcsv($f, $row) === false) {
return false;
}
} // end record loop
rewind($f);
$csv = stream_get_contents($f);
return rtrim($csv);
} catch (PDOExepction $e) {
return $e->getMessage();
}
return $csv;
}
我收到以下错误!
我编写了自己的代码,而不是 fputcsv()。但是,如果在我将 CSV 保存到 javascript 变量时发现问题。有没有其他方法可以将数据转换为 CSV 并将其传递给 javascript? 我将使用 javascript 在客户端将此 csv 转换为 JSON
【问题讨论】:
-
和上面说的差不多。参数 2 应该是一个数组。
foreach ($row as $field => $value) {您正在循环单行,这意味着$field是一个简单的值,而不是一个数组。所以fputcsv($f, $field)失败了。 -
所以没有循环,字段名称只有
fputcsv($f, $row)。
标签: javascript php html fputcsv