Hi,
ich möchte gerne einen Datensatz einlesen, der sich in einer csv-Datei befindet.
Leider ist die Datei so groß, dass der Arbeitsspeicher nicht mehr reicht um diese komplett mit file() einzulesen.
Wie sollte ich nun vorgehen? Ich hole mir die Daten mit copy() von dem Anbieter ab. Kann ich beim copy() die Datei in mehrere Dateien splitten oder was könnte ich sonst noch machen?
Gruß
Marc
Memory Exhaust bei file()
Memory Exhaust bei file()
meine Foren: http://www.maxrev.de/communities.htm
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it
Jemand mit >2700 Beiträgen sollte es doch eigentlich schaffen, die Funktionen des Dateisystems durchzulesen und dann [php:fopen] und [php:fread] finden 

KB:knigge
Ne ich dachte direkt an was in Linux.
Habs mit split() gelöst:
Ist zwar komisch, dass split nur in dem Verzeichnis funktioniert, wo es aufgerufen wird, aber zumindest kann ich den Speicherort definieren.
Danach lese ich das Verzeichnis mit glob() ein und arbeite die Dateien einzeln mit foreach() ab.
Trotzdem Danke!
Habs mit split() gelöst:
Code: Alles auswählen
function splitfile($source)
{
exec("split --lines=5000 $source cache/daten_");
return true;
}
Danach lese ich das Verzeichnis mit glob() ein und arbeite die Dateien einzeln mit foreach() ab.
Trotzdem Danke!
meine Foren: http://www.maxrev.de/communities.htm
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it
Hi,
ich gehe davon aus, dass es schneller ist.
Auch muss man sich keine Gedanken darüber machen welche Zeile ich auslese, wann man stoppt, dass dann in eine Datei packt etc. Also einfach weniger Aufwand. Derzeit mein Ergebnis:
Gruß
ich gehe davon aus, dass es schneller ist.
Auch muss man sich keine Gedanken darüber machen welche Zeile ich auslese, wann man stoppt, dass dann in eine Datei packt etc. Also einfach weniger Aufwand. Derzeit mein Ergebnis:
Code: Alles auswählen
function download($src_file, $dst_file, $gz=false)
{
copy($src_file, $dst_file . ($gz ? '.gz' : ''));
if ( $gz )
{
exec("gunzip $dst_file.gz");
}
chmod($dst_file, 0777);
return true;
}
function splitfile($source, $split)
{
exec("split --lines=500 $source $split");
return true;
}
// Datei lokal sichern
download($csv, $source, $gz);
// Datei splitten
splitfile($source, $split);
meine Foren: http://www.maxrev.de/communities.htm
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it
Ich kaufe Dein Forum! Angebote bitte an marc at gutt punkt it