import itertools
def _yield_sample():
it = iter(itertools.combinations('ABCD', 2))
it2 = iter(itertools.combinations('EFGH', 3))
itc = itertools.chain(it,it2)
for x in itc:
yield x
def main():
for x in _yield_sample():
print x
这样可以打印组合。
>>>
('A', 'B')
('A', 'C')
('A', 'D')
...
但这是:
def __position_combination(_count = [2,3,4,5]):
its = []
for ct in _count:
it = iter(itertools.combinations('ABCDEFG', ct))
its.append(it)
itc = itertools.chain(its)
for x in itc:
yield x
def main():
for x in __position_combination():
print x
不会,它会打印出来
>>>
<itertools.combinations object at 0x02179210>
<itertools.combinations object at 0x02179240>
<itertools.combinations object at 0x02179270>
我必须重写代码以使其按要求工作。
itc = itertools.chain(*its)
我的问题是:
itertools.chain(iter, iter, iter) vs itertools.chain(*[iter,iter,iter])
他们之间有什么不同?根据documentation
itertools.chain
可以:def chain(*iterables):
# chain('ABC', 'DEF') --> A B C D E F
for it in iterables:
for element in it:
yield element
那么,为什么
itertools.chain(iter, iter, iter)
在这里也有效?这是否意味着
iter, iter, iter = *(iter, iter, iter)
? 最佳答案
Yes.
但