【问题标题】:MySQL Query to CSV FormattingMySQL 查询到 CSV 格式
【发布时间】:2014-11-13 15:59:25
【问题描述】:

我有一个包含两个表的数据库:core_members 和 core_fields_content。

core_members 有以下列:member_id、name、email core_pfields_content 包含以下列:member_id、field_1、field_2 等。

我想根据查询中提供的自定义字段值输出选择成员姓名和电子邮件的查询结果并将其导出到 csv 文件。

我希望输出显示在列中,但是在 excel 中打开时,下面的代码在一个单元格中为我提供了以下输出:名称;电子邮件;测试名称;testemail@test.com;

如何更改代码以输出到列中,以列名作为标题?

<?php

    $csv_fileName = 'forumuserlist_'.date('Y-m-d').'.csv';

    // database variables
    $hostname = "localhost";
    $user = "";
    $password = "";
    $database = "";

    // Database connecten voor alle services
    mysql_connect($hostname, $user, $password)
    or die('Could not connect: ' . mysql_error());

    mysql_select_db($database)
    or die ('Could not select database ' . mysql_error());

    $csv_export = '';

    $query = mysql_query("SELECT m.name, m.email FROM core_members m, core_pfields_content p WHERE m.member_id=p.member_id AND p.field_4='LPC'");
    $field = mysql_num_fields($query);

    // create line with field names
    for($i = 0; $i < $field; $i++) {
      $csv_export.= mysql_field_name($query,$i).';';
    }
    $csv_export.= '';
    while($row = mysql_fetch_array($query)) {
      // create line with field values
      for($i = 0; $i < $field; $i++) {
        $csv_export.= $row[mysql_field_name($query,$i)].';';
      } 
      $csv_export.= ''; 
    }

    // Export the data and prompt a csv file for download
    header("Content-type: text/x-csv");
    header("Content-Disposition: attachment; filename=".$csv_fileName."");
    echo($csv_export);
?>

【问题讨论】:

标签: php mysql database csv


【解决方案1】:

从 ; 更改分隔符到 , (COMMA 分隔值 => csv) 并将列名和值括在双引号之间

【讨论】:

  • 替换 ; ,给我不同的单元格,但都在同一行名称电子邮件测试名称 test@test.com
  • 在 while 循环中将 $csv_export.= ''; 更改为 $csv_export.= "\r\n";
猜你喜欢
  • 1970-01-01
  • 2010-09-26
  • 2014-02-02
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多