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

标签 php mysql excel csv

我一直在为一个小型学校项目学习一些 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/

相关文章:

excel - 使用 Python Selenium 下载 Excel 文件

PHP json_encode JSON_PRETTY_PRINT : how to print a different format?

mysql - 如果 id 匹配,则连接最后一列查询结果

python - 在 Excel 中打印输出

mysql - 遍历 MySQL 触发器中的列

MySql 与 NULL 行相乘的列

excel - 确定可见工作表区域大小(以磅为单位)

php - 我的 WordPress 网站初始加载太慢。如何改进?

php - 在 facebook 自定义提要中操作照片 url(图形 API)

php - Instagram 如何在 php 中验证 X-Hub-Signature