Php MySQLi将表导出到CSV
我已经尝试了好几天使用MySQLi从一个查询中导出.csv中的一些值,但是在导出时我遇到了一个问题,所有内容都导出到一个列中,相反,我需要导出类似SQL代码的内容。我在.cvs中有3个选定列和3个导出列。 下面您可以找到两个代码: 1此代码创建数据库、表格并插入值:Php MySQLi将表导出到CSV,php,csv,mysqli,export,Php,Csv,Mysqli,Export,我已经尝试了好几天使用MySQLi从一个查询中导出.csv中的一些值,但是在导出时我遇到了一个问题,所有内容都导出到一个列中,相反,我需要导出类似SQL代码的内容。我在.cvs中有3个选定列和3个导出列。 下面您可以找到两个代码: 1此代码创建数据库、表格并插入值: <?php $servername = "localhost"; $username = "root"; $password = ""; $dbname = "myDB"; // Create connection $conn
<?php
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
// Create database
$sql = "CREATE DATABASE myDB";
if ($conn->query($sql) === TRUE) {
echo "Database created successfully";
} else {
echo "Error creating database: " . $conn->error;
}
// Create connection pt a crea tabela
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
// sql to create table
$sql = "CREATE TABLE MyGuests (
id INT(6) UNSIGNED AUTO_INCREMENT PRIMARY KEY,
firstname VARCHAR(30) NOT NULL,
lastname VARCHAR(30) NOT NULL,
email VARCHAR(50),
reg_date TIMESTAMP
)";
if ($conn->query($sql) === TRUE) {
echo "Table MyGuests created successfully";
} else {
echo "Error creating table: " . $conn->error;
}
// Create connection pt a insera valori
$conn = new mysqli($servername, $username, $password, $dbname);
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
// Insert value in db
$sql = "INSERT INTO MyGuests (firstname, lastname, email)
VALUES ('John', 'Doe, Mark', 'john@example.com'),
('Mary', 'Moe-Johny', 'mary@example.com'),
('Julie', 'Dooley', 'julie@example.com')";
if ($conn->query($sql) === TRUE) {
echo "New record created successfully";
} else {
echo "Error: " . $sql . "<br>" . $conn->error;
}
$conn->close();
?>
我正在使用这个XAMP版本:
Apache/2.4.18 Win32 OpenSSL/1.0.2e PHP/7.0.1
数据库客户端版本:libmysql-mysqlnd 5.0.12-dev-20150407-$Id:7e72f9690b1498a1bead7a637c33a831c0d2f655$
PHP扩展:mysqli文档
PHP版本:7.0.1
这个版本给MySQL代码带来了一些问题,这就是为什么我更喜欢MySQLi中的代码。
多谢各位 根据新信息,我将此作为解决方案
<?php
// call export function
exportMysqlToCsv('export_csv.csv');
// export csv
function exportMysqlToCsv($filename = 'export_csv.csv')
{
$conn = dbConnection();
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql_query = "SELECT id, firstname, lastname FROM MyGuests";
// Gets the data from the database
$result = $conn->query($sql_query);
$f = fopen('php://temp', 'wt');
$first = true;
while ($row = $result->fetch_assoc()) {
if ($first) {
fputcsv($f, array_keys($row));
$first = false;
}
fputcsv($f, $row);
} // end while
$conn->close();
$size = ftell($f);
rewind($f);
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Length: $size");
// Output to browser with appropriate mime type, you choose ;)
header("Content-type: text/x-csv");
header("Content-type: text/csv");
header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=$filename");
fpassthru($f);
exit;
}
// db connection function
function dbConnection(){
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
return $conn;
}
?>
根据新的信息,我将此作为解决方案
<?php
// call export function
exportMysqlToCsv('export_csv.csv');
// export csv
function exportMysqlToCsv($filename = 'export_csv.csv')
{
$conn = dbConnection();
// Check connection
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$sql_query = "SELECT id, firstname, lastname FROM MyGuests";
// Gets the data from the database
$result = $conn->query($sql_query);
$f = fopen('php://temp', 'wt');
$first = true;
while ($row = $result->fetch_assoc()) {
if ($first) {
fputcsv($f, array_keys($row));
$first = false;
}
fputcsv($f, $row);
} // end while
$conn->close();
$size = ftell($f);
rewind($f);
header("Cache-Control: must-revalidate, post-check=0, pre-check=0");
header("Content-Length: $size");
// Output to browser with appropriate mime type, you choose ;)
header("Content-type: text/x-csv");
header("Content-type: text/csv");
header("Content-type: application/csv");
header("Content-Disposition: attachment; filename=$filename");
fpassthru($f);
exit;
}
// db connection function
function dbConnection(){
$servername = "localhost";
$username = "root";
$password = "";
$dbname = "myDB";
// Create connection
$conn = new mysqli($servername, $username, $password, $dbname);
return $conn;
}
?>
您能指出您认为逗号分隔值写入文件的代码行吗?反问句。一个简单的csv行看起来像34,johndoe,而您的代码打印的是id:34-Name:johndoe。因此,至少您必须告诉导入应用程序使用-作为分隔符;但我怀疑结果是否是你想要的。您可能对另一个用户询问如何将MySQL数据转换为csv文件感兴趣。看看这里,我相信这会让你走上正轨:在表格中,巫婆的名字被划分为:,.-/表中的单词用、.-;/请删除。您能指出您认为逗号分隔值写入文件的代码行吗?反问句。一个简单的csv行看起来像34,johndoe,而您的代码打印的是id:34-Name:johndoe。因此,至少您必须告诉导入应用程序使用-作为分隔符;但我怀疑结果是否是你想要的。您可能对另一个用户询问如何将MySQL数据转换为csv文件感兴趣。看看这里,我相信这会让你走上正轨:在表格中,巫婆的名字被划分为:,.-/表中的单词用、.-;/请删除。我是错误:注意:尝试在C:\xampp\htdocs\export\u csv\export\u csv.php的第19行0 results中获取非对象的属性我将所有内容导出到一列中。您可以在这里看到:我想确认该表包含:,.;-/:事实上,这很好,看看附件中的这个例子,这取决于你用什么程序打开文件。事实上,由于它们是逗号分隔的,因此计算机程序可以将其作为有效的csv读取。您可以查看是否可以添加一些格式。看这个例子:它不好。id、firstName和lastName是表头。id->A1;名字->B1;lastname->c1哦,根据我重做函数的新信息,这不是您最初的帖子所做的。我是错误的:注意:试图在第19行0结果中获取C:\xampp\htdocs\export\u csv\export\u csv.php中的非对象属性。我在一列中导出所有内容。您可以在这里看到:我想确认该表包含:,.;-/:事实上,这很好,看看附件中的这个例子,这取决于你用什么程序打开文件。事实上,由于它们是逗号分隔的,因此计算机程序可以将其作为有效的csv读取。您可以查看是否可以添加一些格式。看这个例子:它不好。id、firstName和lastName是表头。id->A1;名字->B1;lastname->c1哦,根据我重做的新信息,这不是你最初的帖子所做的。