This is rather the inverse of What can you use Python generator functions for?: python generators, generator expressions, and the itertools
module are some of my favorite features of python these days. They're especially useful when setting up chains of operations to perform on a big pile of data--I often use them when processing DSV files.
So when is it not a good time to use a generator, or a generator expression, or an itertools
function?
- When should I prefer
zip()
overitertools.izip()
, or range()
overxrange()
, or[x for x in foo]
over(x for x in foo)
?
Obviously, we eventually need to "resolve" a generator into actual data, usually by creating a list or iterating over it with a non-generator loop. Sometimes we just need to know the length. This isn't what I'm asking.
We use generators so that we're not assigning new lists into memory for interim data. This especially makes sense for large datasets. Does it make sense for small datasets too? Is there a noticeable memory/cpu trade-off?
I'm especially interested if anyone has done some profiling on this, in light of the eye-opening discussion of list comprehension performance vs. map() and filter(). (alt link)
<5
. – Pattipattiezip
behaves lazily, anditertools.izip
has been removed. Similarly withrange
andxrange
. – Allness