У меня есть 2 словаря, dict1
и dict2
, которые содержат одни и те же ключи, но разные значения для ключей. То, что я хочу сделать, это для каждого словаря, сортировка значений от наибольшего до наименьшего, а затем дать каждому значению ранг 1-N, 1 - наибольшее значение. Отсюда я хочу получить разницу рангов для значений в каждом словаре для одного и того же ключа. Например:
dict1 = {a:0.6, b:0.3, c:0.9, d:1.2, e:0.2}
dict2 = {a:1.4, b:7.7, c:9.0, d:2.5, e:2.0}
# sorting by values would look like this:
dict1 = {d:1.2, c:0.9, a:0.6, b:0.3, e:0.2}
dict2 = {c:9.0, b:7.7, d:2.5, e:2.0, a:1.4}
#ranking the values would produce this:
dict1 = {d:1, c:2, a:3, b:4, e:5}
dict2 = {c:1, b:2, d:3, e:4, a:5}
#computing the difference between ranks would be something like this:
diffs = {}
for x in dict1.keys():
diffs[x] = (dict1[x] - dict2[x])
#diffs would look like this:
diffs[a] = -2
diffs[b] = 2
diffs[c] = 1
diffs[d] = -2
diffs[e] = 1
Я знаю, что словари должны быть случайными и не сортируемыми, но, возможно, есть способ поместить ключи и значения в список? Главные проблемы, с которыми я сталкиваюсь, - это получить ключи и значения, отсортированные по значению (от самого большого до наименьшего), а затем изменить значение на соответствующий ранг в отсортированном списке.