Python用雷达图展示某学生成绩问题/2020年12月

Python用雷达图展示某学生成绩问题/2020年12月

先摆上成功运行的代码

import numpy as np
import matplotlib.pyplot as plt
import matplotlib
#coding:utf-8
plt.rcParams['font.sans-serif']=['SimHei'] #用来正常显示中文标签,下一行的u也是为了正常显示中文
courses = [u'C++', u'Python', u'高数', u'大学英语', u'电路', u'软件工程', u'计算机网络', u'数据结构']
scores = [80, 95, 78, 85, 50, 72, 82, 90]
#把圆周分为datalength份
datalength = len(scores)  #数据长度
angles = np.linspace(0, 2 * np.pi, datalength, endpoint=False)
#设置为极坐标格式
#这一句似乎非常重要,没有它的话下一句修改标签的语句无法执行,希望有读者能帮作者解释一下【/泪
fig, ax=plt.subplots(figsize=(8, 8), subplot_kw=dict(polar=True))
#修改网格的标签为courses列表
plt.thetagrids(angles * 180 / np.pi, courses)  

#绘制雷达图外部轮廓
plt.plot(angles,scores,'o-',linewidth=1,alpha=0.25)
#填充内部
plt.fill(angles, scores, facecolor='b', alpha=0.2)
plt.show()

由此产生的疑问

我在python3.8.5下一开始复制粘贴别的博客上查到的(不知道最初版本是谁的,并且也懒得考究就不贴来源了)

#HollandRadarDraw.py
import numpy as np
import matplotlib.pyplot as plt 
import matplotlib

matplotlib.rcParams['font.family']="SimHei"
radar_labels = np.array(['研究型(I)','艺术型(A)','社会型(S)',\
                        '企业型(E)','常规型(C)','现实型(R)'])
data = np.array([[0.40, 0.32, 0.35, 0.30, 0.30, 0.88],
                 [0.85, 0.35, 0.30, 0.40, 0.40, 0.30],
                 [0.43, 0.89, 0.30, 0.28, 0.22, 0.30],
                 [0.30, 0.25, 0.48, 0.85, 0.45, 0.40],
                 [0.20, 0.38, 0.87, 0.45, 0.32, 0.28],
                 [0.34, 0.31, 0.38, 0.40, 0.92, 0.28]])
data_labels =('艺术家','实验员','工程师','推销员','社会工作者','记事员')


angles = np.linspace(0, 2*np.pi, 6, endpoint=False)
data = np.concatenate((data, [data[0]]))
angles = np.concatenate((angles, [angles[0]]))
fig = plt.figure(facecolor = "white")
plt.subplot(111, polar = True)
plt.plot(angles, data,'o-',linewidth=1, alpha=0.2)
plt.fill(angles, data, alpha=0.25)
plt.thetagrids(angles*180/np.pi, radar_labels, frac=1.2)
plt.figtext(0.52, 0.95, '霍兰德人格分析', ha='center', size=20)
legend = plt.legend(data_labels, loc = (0.94, 0.80), labelspacing = 0.1)
plt.setp(legend.get_texts(), fontsize='large')
plt.grid(True)
plt.savefig('holland_radar.jpg')
plt.show()

但是运行时卡在

plt.thetagrids(angles*180/np.pi,radar_labels)

这一句,后来参考了 霍兰德人格分析雷达图的两个坑的文章,删除了不必要的部分,后来又跟随自己的理解,成功使我的雷达图运行了,运行效果如下
在这里插入图片描述

  • 5
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 8
    评论
好的,Python有很多绘图库可以用来绘制雷达图,比如matplotlib和plotly。这里我以matplotlib为例,演示如何读取附件中的文件,并绘制成绩雷达图。 首先,假设附件中的文件是一个CSV格式的文件,包含学生姓名和成绩。我们可以使用Python内置的csv模块来读取该文件。以下是读取CSV文件并将数据存储到列表中的示例代码: ```python import csv scores = [] with open('score.csv') as f: reader = csv.reader(f) for row in reader: scores.append(row) ``` 接下来,我们需要将成绩数据转换成适合绘制雷达图的格式。雷达图需要将数据转换成极坐标系下的坐标点,因此我们需要计算每个学生的各个成绩对应的坐标点。以下是将成绩数据转换成坐标点的示例代码: ```python import numpy as np # 将学科名称和对应的角度转换成字典 subject_angles = {'Chinese': 90, 'Math': 30, 'English': 330, 'Physics': 270, 'Chemistry': 210, 'Biology': 150} # 计算每个学生各个成绩对应的坐标点 data = [] for s in scores: name = s[0] values = [float(x) for x in s[1:]] angles = [subject_angles[k] for k in subject_angles.keys()] values += values[:1] angles += angles[:1] data.append((name, angles, values)) ``` 最后,我们使用matplotlib库来绘制雷达图。以下是绘制雷达图的示例代码: ```python import matplotlib.pyplot as plt # 设置雷达图的坐标轴标签和范围 labels = list(subject_angles.keys()) angles = list(subject_angles.values()) angles += angles[:1] plt.polar(angles, labels=labels, color='k', linewidth=1) # 绘制每个学生的雷达图 for d in data: name, angles, values = d values += values[:1] ax = plt.subplot(111, polar=True) ax.plot(angles, values, 'o-', label=name) ax.fill(angles, values, alpha=0.25) ax.set_theta_zero_location('N') ax.set_theta_direction(-1) plt.ylim(0, 100) plt.legend(loc='upper right', bbox_to_anchor=(1.1, 1.1)) plt.show() ``` 这样,我们就可以绘制出每个学生的成绩雷达图了。当然,您需要根据具体的数据格式和绘图需求进行相应的调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值