gpt4 book ai didi

php - 使用 PHP 将 MySQL 输出到 CSV/Excel

转载 作者:行者123 更新时间:2023-11-30 22:06:14 25 4
gpt4 key购买 nike

我一直在为一个小型学校项目学习一些 PHP。该项目几乎完成,只是缺少一件事。我需要一种方法将我搜索到的内容输出到 CSV/Excel 中。我找到了一个我目前正在使用的脚本。它工作得很好,我只是不知道如何为它创建一个搜索表单。

<?php
$DB_Server = "localhost"; //MySQL Server
$DB_Username = "root"; //MySQL Username
$DB_Password = ""; //MySQL Password
$DB_DBName = "database"; //MySQL Database Name
$DB_TBLName = "table"; //MySQL Table Name
$filename = "search"; //File Name
//create MySQL connection
$sql = "Select column1, column2 , ... from $DB_TBLName";
$Connect = @mysql_connect($DB_Server, $DB_Username, $DB_Password) or die("Couldn't connect to MySQL:<br>" . mysql_error() . "<br>" . mysql_errno());
//select database
$Db = @mysql_select_db($DB_DBName, $Connect) or die("Couldn't select database:<br>" . mysql_error(). "<br>" . mysql_errno());
//execute query
$result = @mysql_query($sql,$Connect) or die("Couldn't execute query:<br>" . mysql_error(). "<br>" . mysql_errno());
$file_ending = "xls";
//header info for browser
header("Content-Type: application/xls");
header("Content-Disposition: attachment; filename=$filename.xls");
header("Pragma: no-cache");
header("Expires: 0");
/*******Start of Formatting for Excel*******/
//define separator (defines columns in excel & tabs in word)
$sep = "\t"; //tabbed character
//start of printing column names as names of MySQL fields
for ($i = 0; $i < mysql_num_fields($result); $i++) {
echo mysql_field_name($result,$i) . "\t";
}
print("\n");
//end of printing column names
//start while loop to get data
while($row = mysql_fetch_row($result))
{
$schema_insert = "";
for($j=0; $j<mysql_num_fields($result);$j++)
{
if(!isset($row[$j]))
$schema_insert .= "NULL".$sep;
elseif ($row[$j] != "")
$schema_insert .= "$row[$j]".$sep;
else
$schema_insert .= "".$sep;
}
$schema_insert = str_replace($sep."$", "", $schema_insert);
$schema_insert = preg_replace("/\r\n|\n\r|\n|\r/", " ", $schema_insert);
$schema_insert .= "\t";
print(trim($schema_insert));
print "\n";
}
?>

我让它输出我想要的所有列。我只是不知道如何为它创建搜索表单..尝试调整代码并使用 html 表单解析它的值 - 就像那样

    <form action="index.php" method="GET">
Search :
<input type="text" name="query" />
<input type="submit" value="Search!" />
</form>

最佳答案

您需要向 $sql 添加一个 where 查询。

$sql = 'SELECT * FROM `my_table`;
if (isset($_REQUEST['query']))
{
$sql .= 'WHERE `my_column` = \'' . mysql_real_escape_string($_REQUEST['query']) . '\'';
}

您还需要查看 mysqli_ 而不是 mysql_(mysql 已弃用),因为这将允许您使用准备好的语句。您还应该使用 fputcsv并写入实际文件而不是打印。这将使您无需自己管理即可保留换行符和制表符。

关于php - 使用 PHP 将 MySQL 输出到 CSV/Excel,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41664287/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com