@Taymon使用 list.index 的答案很棒。
FWIW,这是使用itertools模块的功能性方法。它适用于任何可迭代的输入,而不仅仅是列表:
>>> from itertools import compress, count, imap, islice>>> from functools import partial>>> from operator import eq>>> def nth_item(n, item, iterable): indicies = compress(count(), imap(partial(eq, item), iterable)) return next(islice(indicies, n, None), -1)
该示例很好,因为它展示了如何有效地组合Python的功能工具集。请注意,一旦建立了管道,Python的eval循环就不会发生任何事情-
一切都以C速度完成,占用的内存很小,具有惰性的求值方式,没有变量分配,并且具有可单独测试的组件。IOW,这是功能程序员梦dream以求的一切:-)
样品运行:
>>> x = [False,True,True,False,True,False,True,False,False,False,True,False,True]>>> nth_item(50, True, x)-1>>> nth_item(0, True, x)1>>> nth_item(1, True, x)2>>> nth_item(2, True, x)4>>> nth_item(3, True, x)6
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)