首先是一点背景故事。我有一个与自定义创建的票证系统一起使用的数据库。新票证通过使用PHP的HTML表单输入。
我需要能够将某些结果导出到CSV,具体取决于用户在单独表单上选择的内容。
使用PHP快速谷歌MySQL到CSV带来了这个网站。
http://www.a2zwebhelp.com/export-data-to-csv
我稍微修改了代码,以便查询不会从我的表中选择所有列,下面是我修改过的代码。
<?php
// Database Connection
$host="localhost";
$uname="REMOVED";
$pass="REMOVED";
$database = "REMOVED";
$connection=mysql_connect($host,$uname,$pass);
echo mysql_error();
//or die("Database Connection Failed");
$selectdb=mysql_select_db($database) or die("Database could not be selected");
$result=mysql_select_db($database)
or die("database cannot be selected <br>");
// Fetch Record from Database
$output = "";
$table = "site_calls"; // Enter Your Table Name
$sql = mysql_query("select call_id, call_first_name, call_email, call_department, call_subject, call_status, call_user, call_date, call_date2 from $table WHERE (call_user = 15)");
$columns_total = mysql_num_fields($sql);
// Get The Field Name
$columns = ["call_id","call_first_name","call_email","call_department","call_subject","call_status","call_user","call_date","call_date2"];
for ($i = 0; $i < $columns_total; $i++) {
$heading = mysql_field_name($sql, $i);
$output .= '"'.$heading.'",';
}
$output .="\n";
// Get Records from the table
while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$output .='"'.$row["$i"].'",';
}
$output .="\n";
}
// Download the file
$filename = "TicketExport.csv";
header('Content-type: application/csv');
header('Content-Disposition: attachment; filename='.$filename);
echo $output;
exit;
?>
这几乎完全符合我的要求。唯一的问题是,由于时间/日期保存在数据库(Unix)中的方式,2列call_date和call_date2的输出作为Unix输出。我需要这些作为DD / MM / YY或其他人类可读格式出现。我可以使用excel中的公式手动更改它,但这是客户可以访问的内容,并且他们需要能够读取日期。
另外,mysql是折旧的,上面的代码是否有重大变化,以使其在mysqli上运行。系统的其余部分使用mysqli编写,用于输入数据。
TL:DR。从MYSQL数据库导出一些列,需要使用php将2列从Unix转换为可读日期/时间。
答案 0 :(得分:0)
在for循环中使用if语句来识别你在日期列上,然后调用php date函数重新格式化。
像这样:
for ($i = 0; $i < $columns_total; $i++) {
if($i == 7 or $i == 8) {
$output .='"'.date('d/m/y', strtotime($row["$i"])).'",';
} else {
$output .='"'.$row["$i"].'",';
}
}
我希望这有帮助!
答案 1 :(得分:0)
试试这个:
while ($row = mysql_fetch_array($sql)) {
for ($i = 0; $i < $columns_total; $i++) {
$heading = mysql_field_name($sql, $i);
if ($heading == 'call_date' || $heading == 'call_date2') {
$output .= '"'.date('d/m/y', strtotime($row["$i"])).'",';
}
else {
$output .='"'.$row["$i"].'",';
}
}
$output .="\n";
}