0

我有一个结构类似于的数组 $data = array{0=>'abc',1=>xyz,2=>tqs}

现在我需要将这些值写入 csv 文件。我需要显示第一列中的每个值,并且每次插入新行时都会显示新行以及已经可用的先前值。

下面是我正在使用的代码,但每次执行它时,我都会得到文件中的最后一个值:

for ($c=0; $c < $num; $c++) {
      echo $data[$c];
   echo  $query = "select prod_sku,prod_name 
    from
      tbl_product
    where 
     prod_sku = '".$data[$c]."'";
     $result = mysql_query($query);
     $row = mysql_fetch_array($result);
     if(empty($row)){
     print_r($row);
     echo 'test';
     $fp = fopen("file.csv", "w");
     print_r($data[0]);

      fputcsv($fp, $data[0]);
      fclose($fp);


  } 

我如何使用 PHP 来实现这一点?

4

2 回答 2

5

问题是你fopen在 for 循环内做,所以每次循环运行时,你的文件都会被重写。将fopenandfclose移到循环之外,它将起作用。像这样;

$fp = fopen("file.csv", "w");
for ($c=0; $c < $num; $c++)
{
     $query = "select prod_sku,prod_name from tbl_product where prod_sku = '".$data[$c]."'";
     $result = mysql_query($query);
     $row = mysql_fetch_array($result);

     fputcsv($fp, $data);
} 
fclose($fp);
于 2010-11-27T09:27:18.223 回答
0

如果您使用 MySQL,您可以使用SELECT ... INTO OUTFILE

SELECT prod_sku, prod_name
INTO OUTFILE '/tmp/products.csv'
FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"'
ESCAPED BY '\\'
LINES TERMINATED BY '\n'
FROM tbl_product
WHERE 1

http://dev.mysql.com/doc/refman/5.0/en/select.html

于 2010-11-27T09:49:20.177 回答