I have a 3GB CSV file that I try to read with python, I need the median column wise.
from numpy import *
def data():
return genfromtxt('All.csv',delimiter=',')
data = data() # This is where it fails already.
med = zeros(len(data[0]))
data = data.T
for i in xrange(len(data)):
m = median(data[i])
med[i] = 1.0/float(m)
print med
The error that I get is this:
Python(1545) malloc: *** mmap(size=16777216) failed (error code=12)
*** error: can't allocate region
*** set a breakpoint in malloc_error_break to debug
Traceback (most recent call last):
File "Normalize.py", line 40, in <module>
data = data()
File "Normalize.py", line 39, in data
return genfromtxt('All.csv',delimiter=',')
File "/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/site-
packages/numpy/lib/npyio.py", line 1495, in genfromtxt
for (i, line) in enumerate(itertools.chain([first_line, ], fhd)):
MemoryError
I think it’s just an out of memory error. I am running a 64bit MacOSX with 4GB of ram and both numpy and Python compiled in 64bit mode.
How do I fix this? Should I try a distributed approach, just for the memory management?
Thanks
EDIT: Also tried with this but no luck…
genfromtxt('All.csv',delimiter=',', dtype=float16)
As other folks have mentioned, for a really large file, you’re better off iterating.
However, you do commonly want the entire thing in memory for various reasons.
genfromtxtis much less efficient thanloadtxt(though it handles missing data, whereasloadtxtis more “lean and mean”, which is why the two functions co-exist).If your data is very regular (e.g. just simple delimited rows of all the same type), you can also improve on either by using
numpy.fromiter.If you have enough ram, consider using
np.loadtxt('yourfile.txt', delimiter=',')(You may also need to specifyskiprowsif you have a header on the file.)As a quick comparison, loading ~500MB text file with
loadtxtuses ~900MB of ram at peak usage, while loading the same file withgenfromtxtuses ~2.5GB.Loadtxt

Genfromtxt

Alternately, consider something like the following. It will only work for very simple, regular data, but it’s quite fast. (
loadtxtandgenfromtxtdo a lot of guessing and error-checking. If your data is very simple and regular, you can improve on them greatly.)Fromiter