![](/img/trans.png)
[英]Python Basics: for i, element in enumerate(seq)..why/how does this work?
[英]Why does enumerate() not work as intended here?
我试图使用 enumerate 在每 n 次迭代中做一些事情。 在下面的示例中,我使用了一个分块的可迭代对象。 原始的可迭代对象是一个包含 1000000 个 URL 和生成器的列表,它被分成 1000 个块。 现在,如果我使用:
if count % 2 == 0:
它按预期工作,即每隔一个块,它打印出abc 。 但是,如果我尝试使用:
if count % 1 == 0:
它不是在每个块完成后打印出abc ,而是在原始列表中的每个单独项目完成后打印abc 。 换句话说,我得到了一百万个abc输出而不是 1000 个。我做错了什么?
def chunk_iterable(iterable, chunk_size):
chunk = []
for item in iterable:
chunk.append(item)
if len(chunk) == chunk_size:
yield chunk
chunk = []
if chunk:
yield chunk
async def make_async_requests(directory, file, urls):
sem = asyncio.BoundedSemaphore(50)
chunk_size = 10000
async with aiohttp.ClientSession() as session:
for count, chunk in tqdm.tqdm(enumerate(chunk_iterable(urls, chunk_size)), total=len(urls)/chunk_size)):
await tqdm.asyncio.tqdm.gather(*[write_to_file(url, sem, session) for url in chunk])
if count % 1 == 0:
print("abc")
continue
这里的问题不是enumerate()
,而是这里模运算符的使用:
if count % 1 == 0:
这种情况将始终为真,因为 1 的模将始终为零,如果您想要一千个输出而不是一百万(如果它是一百万)尝试:
if count % 1000 == 0:
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.