在列表中查找具有等于某个值的属性(符合任何条件)

我有对象列表。 我想在这个列表中find一个(第一个或其他)对象,它的属性(或方法结果 – 不pipe)等于value

什么是find它的最好方法?

这里是testing用例:

  class Test: def __init__(self, value): self.value = value import random value = 5 test_list = [Test(random.randint(0,100)) for x in range(1000)] # that I would do in Pascal, I don't believe isn't anywhere near 'Pythonic' for x in test_list: if x.value == value: print "i found it!" break 

我认为使用生成器和reduce()不会有什么区别,因为它仍然会遍历整个列表。

ps:等式的value只是一个例子。 当然,我们要获得满足任何条件的元素。

 next((x for x in test_list if x.value == value), None) 

这将获得匹配条件的列表中的第一个项目,如果没有项目匹配,则返回None 。 这是我首选的单expressionforms。

然而,

 for x in test_list: if x.value == value: print "i found it!" break 

天真的循环打破版本,是完美的Pythonic – 它简洁,清晰,高效。 为了使之与单行的行为相匹配:

 for x in test_list: if x.value == value: print "i found it!" break else: x = None 

如果你没有break循环,这将会把None赋值给x

我遇到了类似的问题,为列表中没有任何对象符合要求的情况devise了一个小的优化(对于我的使用情况,这导致了性能的大幅提升):

随着列表test_list,我保留了一个额外的设置test_value_set,其中包含我需要过滤的列表的值。 所以这里agf的解决scheme的其他部分变得非常快。

由于没有提到只是为了完成。 好olfilter来过滤你的过滤元素。

函数式编程ftw。

 ####### Set Up ####### class X: def __init__(self, val): self.val = val elem = 5 my_unfiltered_list = [X(1), X(2), X(3), X(4), X(5), X(5), X(6)] ####### Set Up ####### ### Filter one liner ### filter(lambda x: condition(x), some_list) my_filter_iter = filter(lambda x: x.val == elem, my_unfiltered_list) ### Returns a flippin' iterator at least in Python 3.5 and that's what I'm on print(next(my_filter_iter).value) print(next(my_filter_iter).value) print(next(my_filter_iter).value) ### [1, 2, 3, 4, 5, 5, 6] Will Return: ### # 5 # 5 # Traceback (most recent call last): # File "C:\Users\mousavin\workspace\Scripts\test.py", line 22, in <module> # print(next(my_filter_iter).value) # StopIteration # # You can do that None stuff or whatever at this point, if you don't like exceptions. 

我知道,通常在Python列表parsing是首选或至less这是我读的,但我不认为这个问题是诚实的。 当然,Python不是一种FP语言,但Map / Reduce / Filter是完全可读的,是function性编程中最标准的标准用例。

所以你去了 知道你的function编程。

过滤条件列表

它不会比这更容易:

 next(filter(lambda x: x.value == value, test_list)