疲惫的迭代器-如何处理?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了疲惫的迭代器-如何处理?相关的知识,希望对你有一定的参考价值。
(在Python 3.1中(与another question I asked有点相关,但是这个问题是关于迭代器已用尽。)
# trying to see the ratio of the max and min element in a container c
filtered = filter(lambda x : x is not None and x != 0, c)
ratio = max(filtered) / min(filtered)
我花了半个小时才意识到问题出在哪里(过滤器返回的迭代器在到达第二个函数调用时已经用尽了)。如何以最Pythonic /规范的方式重写它?
此外,除了获得更多经验之外,我还可以采取哪些措施来避免此类错误? (坦率地说,我不喜欢这种语言功能,因为这些类型的错误易于制造且难以捕获。)
您可以简单地通过调用tuple(iterator)
将迭代器转换为元组>
但是我会将该过滤器重写为列表理解,看起来像这样
itertools.tee
功能可以在这里提供帮助:
实际上,您的代码引发了一个防止此问题的异常!所以我想问题是您掩盖了异常吗?
实体def minmax( seq ):
" returns the `(min, max)` of sequence `seq`"
it = iter(seq)
try:
min = max = next(it)
except StopIteration:
raise ValueError('arg is an empty sequence')
for item in it:
if item < min:
min = item
elif item > max:
max = item
return min, max
本质上是具有状态的对象。当然,now
以上是关于疲惫的迭代器-如何处理?的主要内容,如果未能解决你的问题,请参考以下文章
在 python 中进行迭代时如何处理日期时间的 NaT 值?