def list_step(max = 268):
""" split in steps of 120 elements at time
"""
if max > 120:
for i in xrange(0,max,120):
if i <= max:
rest = max % xrange(0,max,120)[-1]
if rest != 120:
yield(i, rest)
else:
yield(i, 0)
else:
yield(max)
a = list_step()
a.next() return > (0,28) (120,28),ecc是否有可能在执行last ()时返回其余部分,而不是在其余部分返回元组?
因此:
a.next() return > (0) (120),ecc.. (28)发布于 2015-03-20 10:29:25
像这样吗?
def list_step(max = 268):
""" split in steps of 120 elements at time
"""
if max > 120:
rest_list = [];
for i in xrange(0,max,120):
if i <= max:
rest = max % xrange(0,max,120)[-1]
if rest != 120:
yield(i)
rest_list.append(rest)
else:
yield(i)
rest_list.append(0)
for i in rest_list:
yield(i)
else:
yield(max)
a = list_step()
for i in a: print i;发布于 2015-03-20 10:32:07
您可以使用itertools.chain将迭代器链接在一起(文档)。如果您只是想要将单个值“附加”到生成器中,则可以使用它(请注意,您需要以某种方式将单个项转换为可迭代的)。
而且,您的max % xrange(0, max, 120)[-1]将始终是max % 120,因为xrange(0, max, 120)是最大值,其倍数为120,小于最大值,因此除以它将产生与除以120 (模块化)相同的结果。
import itertools
itertools.chain(xrange(0,max,120), [max % 120])https://stackoverflow.com/questions/29164163
复制相似问题