计算列表中字典值的中值

2024-04-27 23:27:39 发布

您现在位置:Python中文网/ 问答频道 /正文

我想计算列表中“分数”(字典值)的中位数

my_dict = {"John": [{"class": "math", "score": 100, "year": 2014}, {"class": "english", "score": 85, "year": 2015}, {"class": "science", "score": 90, "year": 2015}], 
"Timmy": [{"class": "math", "score": 87, "year": 2014}, {"class": "english", "score": 91, "year": 2015}], 
"Sally":[{"class": "math", "score": 95, "year": 2014}]}

输出如下所示:

new_dict = {"John": 90, "Timmy": 89, "Sally": 95}

我想我需要根据分数对我的字典进行排序,然后计算中值。如果不使用外部软件包,就无法完全理解这两个步骤

任何帮助都将不胜感激!Python新手


Tags: 列表字典englishmymathjohnyear分数
3条回答
my_dict = {"John": [{"class": "math", "score": 100, "year": 2014}, {"class": "english", "score": 85, "year": 2015}, {"class": "science", "score": 90, "year": 2015}], 
"Timmy": [{"class": "math", "score": 87, "year": 2014}, {"class": "english", "score": 91, "year": 2015}], 
"Sally":[{"class": "math", "score": 95, "year": 2014}]}

import numpy as np
medians = {}
for k in my_dict.keys():
    ls = []
    for d in my_dict[k]:
        ls.append(d['score'])
    medians[k] = np.median(ls)

print(medians)

输出:

{'Sally': 95.0, 'Timmy': 89.0, 'John': 90.0}

您可以使用numpy.median来计算中位数

您可以使用来自statistics的中间值

from statistics import median

my_dict = {"John": [{"class": "math", "score": 100, "year": 2014}, {"class": "english", "score": 85, "year": 2015}, {"class": "science", "score": 90, "year": 2015}], 
"Timmy": [{"class": "math", "score": 87, "year": 2014}, {"class": "english", "score": 91, "year": 2015}], 
"Sally":[{"class": "math", "score": 95, "year": 2014}]}

new_dict = {}

for k, v in my_dict.items():
  m = []
  for l in v:
    m.append(l["score"])
  new_dict[k] = median(m)

print(new_dict)

如果不想使用软件包编写自己的函数,可以调用:

def median(lst):
    n = len(lst)
    s = sorted(lst)
    return (sum(s[n//2-1:n//2+1])/2.0, s[n//2])[n % 2] if n else None

使用median和dict理解的一行程序

from statistics import median 
{k:median([v.get('score',0) for v in my_dict[k]]) for k in my_dict.keys()}

输出:

{'John': 90, 'Timmy': 89.0, 'Sally': 95}

相关问题 更多 >