list_of_elements = [1255, 1256, 1257, 1258, 1259]
print(components[1255],components[1256],components[1257],components[1258],components[1259])
打印输出为:
[481, 498, 5142, 5157] [481, 497, 5192, 5199] [481, 498, 5219, 5238] [481, 484, 5239, 5242] [481, 487, 5269, 5271)]
我想做的是获取第一个索引(0)的最小数量,第二个索引的最大数量,第二个索引的最小数量,第四个索引的最大数量,因此在这种情况下我将得出以下结论:
[481,498,5142,5271]
所以,再次,基本上,我将得到一个元素列表(在这种情况下list_of_elements
,可能是0个值,直到未知),然后我必须将该列表的元素作为字典中的键输入,components
并执行上述步骤。
这是通过调度程序字典和几个列表推导来构造逻辑的一种方法:
list_of_elements = [1255, 1256, 1257, 1258, 1259]
# extract data via list comprehension
L = [components[i] for i in list_of_elements]
# defined explicitly for demonstration
L = [[481, 498, 5142, 5157], [481, 497, 5192, 5199],
[481, 498, 5219, 5238], [481, 484, 5239, 5242],
[481, 487, 5269, 5271]]
from operator import itemgetter
# define dispatcher dictionary
funcs = {0: min, 1: max}
# apply via list comprehension
res = [funcs[i%2](map(itemgetter(i), L)) for i in range(len(L[0]))]
print(res)
[481, 498, 5142, 5271]
说明
i%2
返回0或1,具体取决于您的索引是偶数还是奇数。funcs[i%2]
返回min
或max
在funcs
字典中定义。map(itemgetter(i), L)
在中的i
每个列表的th元素上返回一个迭代器L
。funcs[i%2]
在此迭代器上应用将返回最小值或最大值。本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句