]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Improve itertools docs with clearer examples of pure python equivalent code.
authorRaymond Hettinger <python@rcn.com>
Sun, 30 Oct 2011 21:53:17 +0000 (14:53 -0700)
committerRaymond Hettinger <python@rcn.com>
Sun, 30 Oct 2011 21:53:17 +0000 (14:53 -0700)
Doc/library/itertools.rst

index b7f407d6c65ac572acfafd239c3ed7fa778f382e..36a391b4095e8f743d30e2444d4093bc9c77df72 100644 (file)
@@ -433,9 +433,9 @@ loops that truncate the stream.
 
       def izip(*iterables):
           # izip('ABCD', 'xy') --> Ax By
-          iterables = map(iter, iterables)
-          while iterables:
-              yield tuple(map(next, iterables))
+          iterators = map(iter, iterables)
+          while iterators:
+              yield tuple(map(next, iterators))
 
    .. versionchanged:: 2.4
       When no iterables are specified, returns a zero length iterator instead of
@@ -456,17 +456,24 @@ loops that truncate the stream.
    iterables are of uneven length, missing values are filled-in with *fillvalue*.
    Iteration continues until the longest iterable is exhausted.  Equivalent to::
 
+      class ZipExhausted(Exception):
+          pass
+
       def izip_longest(*args, **kwds):
           # izip_longest('ABCD', 'xy', fillvalue='-') --> Ax By C- D-
           fillvalue = kwds.get('fillvalue')
-          def sentinel(counter = ([fillvalue]*(len(args)-1)).pop):
-              yield counter()         # yields the fillvalue, or raises IndexError
+          counter = [len(args) - 1]
+          def sentinel():
+              if not counter[0]:
+                  raise ZipExhausted
+              counter[0] -= 1
+              yield fillvalue
           fillers = repeat(fillvalue)
-          iters = [chain(it, sentinel(), fillers) for it in args]
+          iterators = [chain(it, sentinel(), fillers) for it in args]
           try:
-              for tup in izip(*iters):
-                  yield tup
-          except IndexError:
+              while iterators:
+                  yield tuple(map(next, iterators))
+          except ZipExhausted:
               pass
 
    If one of the iterables is potentially infinite, then the