should I transfer 'iterators' between functions?
Peter Otten
__peter__ at web.de
Sat Jan 25 08:32:18 EST 2014
Ned Batchelder wrote:
> On 1/25/14 1:37 AM, seaspeak at gmail.com wrote:
>> take the following as an example, which could work well.
>> But my concern is, will list 'l' be deconstructed after function return?
>> and then iterator point to nowhere?
>>
>> def test():
>> l = [1, 2, 3, 4, 5, 6, 7, 8]
>> return iter(l)
>> def main():
>> for i in test():
>> print(i)
>>
>>
>
> One more thing: there's no need to call iter() explicitly here. Much
> more common than returning an iterator from a function is to return an
> iterable. Your code will work exactly the same if you just remove the
> iter() call:
>
> def test():
> l = [1, 2, 3, 4, 5, 6, 7, 8]
> return l
> def main():
> for i in test():
> print(i)
For that specific client code, yes. In the general case the difference
matters. Iteration over an iterable starts at the beginning while iteration
over an iterator starts at the current item:
>>> def main():
... items = test()
... print(list(zip(items, items)))
...
>>> def test(): return range(6) # an iterable
...
>>> main()
[(0, 0), (1, 1), (2, 2), (3, 3), (4, 4), (5, 5)]
>>> def test(): return iter(range(6)) # an iterator
...
>>> main()
[(0, 1), (2, 3), (4, 5)]
More information about the Python-list
mailing list