Problem:
Ein Java-Programm versucht, CSV-Daten in SQL-Befehle umzuwandeln hat Probleme mit der Ausgabedatei. Nicht alle in BufferedWriter geschriebenen Daten erscheinen in der Ausgabedatei.
Details:
Das Programm liest eine CSV-Datei mit über 10.000 Zeilen und generiert SQL-Anweisungen zum Einfügen der Daten in eine Tabelle. Allerdings wird die Ausgabedatei mittendrin abgeschnitten, da in der letzten unvollständigen Anweisung ein Teil eines Werts fehlt.
Code:
// ... while((line = in.readLine())!= null) { String[] esa = line.split(","); sqlstr = "insert into nyccrash values ("+esa[0]+", "+esa[1]+", "+esa[2]+", "+esa[3]+", "+esa[4]+", "+esa[5]+", "+esa[6]+");\n"; out.write(sqlstr); } // ...
Lösung:
Das Problem entsteht, weil der Ausgabepuffer während des Schreibvorgangs nicht geleert wird. Die Standardpuffergröße für BufferedWriter beträgt 8192 Zeichen und reicht aus, um mehrere Zeilen aufzunehmen. Nachdem der Puffer voll ist, werden Daten nicht in die Datei geschrieben, bis der Puffer manuell geleert wird.
Um sicherzustellen, dass alle Daten in die Ausgabedatei geschrieben werden, ist es notwendig, den OutputStream explizit zu schließen, der alle verbleibenden Daten löscht Daten im Puffer:
out.close();
Das Schließen des Ausgabestreams garantiert, dass alle Daten, einschließlich der Teilanweisung, in die Datei geschrieben werden, bevor das Programm beendet wird.
Das obige ist der detaillierte Inhalt vonWarum schreibt mein BufferedWriter nicht alle Daten in die Ausgabedatei?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!