I am trying to use zipfile module to read a file in an archive. the uncompressed file is ~3GB and the compressed file is 200MB. I don’t want them in memory as I process the compressed file line by line. So far I have noticed a memory overuse using the following code:
import zipfile
f = open(...)
z = zipfile.ZipFile(f)
for line in zipfile.open(...).readlines()
print line
I did it in C# using the SharpZipLib:
var fStream = File.OpenRead("...");
var unzipper = new ICSharpCode.SharpZipLib.Zip.ZipFile(fStream);
var dataStream = unzipper.GetInputStream(0);
dataStream is uncompressed. I can’t seem to find a way to do it in Python. Help will be appreciated.
Python file objects provide iterators, which will read line by line.
file.readlines()reads them all and returns a list – which means it needs to read everything into memory. The better approach (which should always be preferred overreadlines()) is to just loop over the object itself, E.g:Note my use of the
withstatement – file objects are context managers, and the with statement lets us easily write readable code that ensures files are closed when the block is exited (even upon exceptions). This, again, should always be used when dealing with files.