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ループ内で実行しているため、ループが実行されるたびにファイルが再書き込みされることです。とをループの外側に移動するfopenと、機能します。fcloseこのような;

$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 に答える