製品の配列を CSV ファイルに変換するという目標は効果的に達成できます。ただし、対処すべき微妙な点があります。
コードでは、主な問題は複数のループの使用にあるようです。これにより、望ましくない単一行の CSV 出力が発生する可能性があります。
< ;h3>より良い解決策
これを克服するには、組み込みの PHP 関数 fputcsv() の使用を検討してください。改善されたコード スニペットは次のとおりです。
<code class="php">$sql = "SELECT id, name, description FROM products"; if ($result = $mysqli->query($sql)) { $output = fopen("php://output", 'w') or die("Can't open php://output"); header("Content-Type:application/csv"); header("Content-Disposition:attachment;filename=pressurecsv.csv"); fputcsv($output, array('id', 'name', 'description')); while ($p = $result->fetch_array()) { fputcsv($output, $p); } fclose($output) or die("Can't close php://output"); }</code>
この改訂されたアプローチでは、
注: 保存したくない場合は、ファイルを作成した後に忘れずに unlink() してください。サーバー上にコピーが保存されます。
これらの変更を実装すると、期待どおりにヘッダーと改行を含む整形式の CSV ファイルを生成できます。
以上がPHP 配列から CSV への変換の問題を解決し、優れたアプローチを実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。