我怎样才能找到某个元素在集合中的位置的索引。所以我想找到
(2.0, 2.0, 152)
位于 sets
列表中的位置,这是第 5 个索引。我可以使用一个函数来实现这一点吗?
from itertools import groupby
from itertools import accumulate
import itertools
#Configs
Lower = [round(x * 0.5,1) for x in range(4,23)] #ideal = (4,13) Lower and upper boundary values
Upper = [round(x * 0.5,1) for x in range(4,23)] # ideal between (10-23)
number = [round(x *0.5,5) for i in range(100, )] #used for calculations with stand deriv and linear reg
list_set = [Lower, Upper, number]
sets = []
for element in itertools.product(*list_set):
print(element)
sets.append(element)
有两种方法可以在 Python 中从数组中查找元素的索引。
第一种也是最直接的方法是使用任何列表的
.index()
方法,该方法返回指定值所在的索引。举个例子:
list = [123, 417, 098]
print(list.index(417))
您可以在这里看到它将打印一个,因为这是
417
位于 list
数组中的索引。不过,请记住,如果指定的值不存在,您可能会收到错误。
第二种更难的方法是自己迭代数组。举个例子:
list = [123, 417, 098]
def findElement(array, element):
for index in range(len(array)):
if (array[index] == element):
return index
print(findElement(list, 417))
我们在这里所做的是定义一个方法,该方法将一个数组和一个元素作为参数,然后迭代列表的每个索引,直到该索引处的值是指定的元素。当值匹配时,它将返回所述索引。如果没有值匹配,它将不会返回任何内容。
第二种方法的优点是如果列表中没有这样的元素,它不会抛出错误,但是设置起来也有点困难。
try:
print(sets.index(element))
except:
print('not found')
如果你想使用更好的保留在字典索引中,它可以在 O(1) 时间内检索你的索引。但是构造可能需要 O(n) 时间