3

假设我想创建一个接受迭代的函数。该可迭代对象可能包含任何级别的其他可迭代对象。我想创建一个按顺序遍历这些的函数。例如:

import collections
def it(l):
  for i in l:
    if isinstance(i, collections.Iterable):
      it(i) 
    else:
      print i


it([ [1, 2, 3], [[4, [5, 6]], 7], 8, [9, 10]])  

这会产生以下输出(如预期的那样):1 2 3 4 5 6 7 8 9 10

不应该我想用发电机来做这个。为什么以下工作不像我期望的那样工作(基本上用产量替换打印语句):

import collections
def it(l):
  for i in l:
    if isinstance(i, collections.Iterable):
      it(i) 
    else:
      yield i

谢谢!

4

1 回答 1

5

因为当你递归时,你会返回一个新的生成器——但是那个生成器永远不会产生任何东西,因为你没有迭代它。相反,请执行以下操作:

def it(l):
  for i in l:
    if isinstance(i, collections.Iterable):
      for item in it(i):
        yield item
    else:
      yield i

或者,在 python3.3 中,您可以使用yield from关键字。

于 2013-10-01T22:11:40.420 回答