Ihr Code zielt darauf ab, ein Array von Produkten in eine CSV-Datei zu konvertieren, aber Sie stoßen auf Probleme, die zu einer einzeiligen Ausgabe führen ohne einen richtigen Download-Header.
Die Hauptursache der einzeiligen Ausgabe liegt in den verschachtelten Schleifen, die den CSV-Inhalt erstellen. Erwägen Sie, den Prozess mit der Funktion fputcsv() zu optimieren, anstatt die CSV manuell zu erstellen. Dies vereinfacht den Vorgang und gewährleistet die ordnungsgemäße Formatierung.
Um einen Datei-Download auszulösen, müssen Sie die entsprechenden HTTP-Header festlegen. So können Sie das tun:
<code class="php">header("Content-type: application/octet-stream"); header("Content-Disposition: attachment; filename=your_desired_name.csv");</code>
Der bereitgestellte Code schreibt die CSV-Datei jedoch direkt in den Ausgabestream, sodass sie für JavaScript-Bibliotheken, die Sie möglicherweise für die clientseitige Verarbeitung verwenden, nicht zugänglich ist.
Hier ist ein alternativer Ansatz, der diese Probleme mit fputcsv() behebt:
<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>
Dieser Code erstellt die CSV-Datei und streamt sie in den Ausgabepuffer. Die Funktion fputcsv() verarbeitet Formatierungen und Escape-Werte automatisch. Die letzte Zeile schließt den Ausgabestream und gibt Ressourcen frei.
Das obige ist der detaillierte Inhalt vonWie gehe ich mit einzeiliger Ausgabe und dem Herunterladen von Dateien um, wenn ich ein PHP-Array in CSV konvertiere?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!