如何在Python中该列表的子列表中最小的列表中找到元素的索引?

时间:2018-11-04 09:52:35

标签: python list indexing

假设我有一个Python列表:

x = [3,6,4,8,1,9]

并且我想找到列表中元素的索引,这是子列表中的最小值(例如,从索引 2 4 )。

所以我想获得一个子列表x[2:5]并获取最小元素的索引(在这种情况下为x[4])。

在这种情况下如何返回索引4?如果我在子列表上使用np.argmin(),它将根据子列表返回索引(在这种情况下,np.argmin(x [2:5])将返回2,根据子列表是正确的)。 / p>

我不想使用多个if-else条件。如何在短时间内获取该索引?

3 个答案:

答案 0 :(得分:5)

只需在子列表开始处添加索引,您将拥有原始索引:

x = [3,6,4,8,1,9]
subl_start = 2
subl_end = 5

ind_min = np.argmin(x[subl_start: subl_end]) + subl_start

答案 1 :(得分:2)

您还可以找到阈值之间的最小数字:

>>> x = [3,6,4,8,1,9]
>>> start, end = 2, 5
>>> min((e, i) for i, e in enumerate(x) if start <= i < end)[1]
4

或增加最终结果索引:

>>> min((e, i) for i, e in enumerate(x[start:end]))[1] + start
4

答案 2 :(得分:0)

我认为这支衬板适合您的情况。

@background(schedule=10000)
def check_deadline(repeat=30000):
     # Check if deadline has crossed from DB
     # Return the record's title whose deadline has crossed

您也可以用一些变量替换2和5。 (对于从n到m的索引->(arr [n:m + 1]))