在Python中找到列表中元素的索引的好方法是什么? 注意,列表可能没有排序。
是否有方法指定要使用的比较运算符?
在Python中找到列表中元素的索引的好方法是什么? 注意,列表可能没有排序。
是否有方法指定要使用的比较运算符?
当前回答
最好的方法可能是使用列表方法。index。
对于列表中的对象,你可以这样做:
def __eq__(self, other):
return self.Value == other.Value
您需要的任何特殊处理。
你也可以在enumerate(arr)中使用for/in语句
使用实例查找值为> 100的项的索引。
for index, item in enumerate(arr):
if item > 100:
return index, item
源
其他回答
列表的索引方法将为您完成此工作。如果想要保证顺序,请先使用sorted()对列表进行排序。Sorted接受cmp或key参数来指示如何进行排序:
a = [5, 4, 3]
print sorted(a).index(5)
Or:
a = ['one', 'aardvark', 'a']
print sorted(a, key=len).index('a')
这个怎么样?
def global_index(lst, test):
return ( pair[0] for pair in zip(range(len(lst)), lst) if test(pair[1]) )
用法:
>>> global_index([1, 2, 3, 4, 5, 6], lambda x: x>3)
<generator object <genexpr> at ...>
>>> list(_)
[3, 4, 5]
如果你只是想知道一个元素是否包含在列表中:
>>> li
['a', 'b', 'new', 'mpilgrim', 'z', 'example', 'new', 'two', 'elements']
>>> 'example' in li
True
>>> 'damn' in li
False
有索引方法,i = array.index(value),但我不认为你可以指定一个自定义比较运算符。不过,编写自己的函数来实现这一点并不难:
def custom_index(array, compare_function):
for i, v in enumerate(array):
if compare_function(v):
return i
最好的方法可能是使用列表方法。index。
对于列表中的对象,你可以这样做:
def __eq__(self, other):
return self.Value == other.Value
您需要的任何特殊处理。
你也可以在enumerate(arr)中使用for/in语句
使用实例查找值为> 100的项的索引。
for index, item in enumerate(arr):
if item > 100:
return index, item
源