Prawdopodobnie powinieneś użyć textscan wczytać dane porcjami, a następnie przetworzyć. Będzie to prawdopodobnie bardziej efektywne niż czytanie jednej linii na raz. Na przykład, jeśli masz 3 kolumny danych, możesz wykonać:
filename = 'fname.csv';
[fh, errMsg] = fopen( filename, 'rt' );
if fh == -1, error( 'couldn''t open file: %s: %s', filename, errMsg ); end
N = 100; % read 100 rows at a time
while ~feof( fh )
c = textscan( fh, '%f %f %f', N, 'Delimiter', ',' );
doStuff(c);
end
EDYTUJ
Obecnie (R2014b i nowsze) łatwiej i prawdopodobnie bardziej wydajnie jest używać datastore
.