假设我有一个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条件。如何在短时间内获取该索引?
答案 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]))