当前位置:   article > 正文

霍兰德人格分析雷达图

霍兰德人格分析雷达图

雷达图 Radar Chart

雷达图是多特性直观展示的重要方式

问题分析

霍兰德认为:人格兴趣与职业之间应有一种内在的对应关系

人格分类:研究型、艺术型、社会型、企业型、传统型、现实性

职业:工程师、实验员、艺术家、推销员、记事员、社会工作者

需求:雷达图方式验证霍兰德人格分析 - 输入:各职业人群结合兴趣的调研数据 - 输出:雷达图

分析:

这段代码的作用是绘制一个极坐标系下的雷达图,其中包含了职业类型和对应的6个特质分数的数据。具体步骤如下:

  1. 导入所需的库:numpy和matplotlib.pyplot。

  2. 设置中文标签显示:将默认字体设置为中文黑体。

  3. 定义数据:一个6行6列的矩阵,表示6个职业的6个特质分数。

  4. 定义角度:使用numpy的linspace函数生成6个角度,作为雷达图的x轴坐标。

  5. 重复第一个角度:为了让图像闭合,将第一个角度再添加到数组的最后。

  6. 定义职业标签:一个包含7个字符串元素的列表。

  7. 绘制雷达图:通过循环绘制每个职业的特质分数图形。在循环中,使用ax.plot函数绘制特质分数的折线图,并使用ax.fill函数填充颜色。

  8. 添加坐标轴标签:使用ax.set_thetagrids函数添加角度轴的标签。

  9. 添加标题:使用plt.title函数添加图表标题。

  10. 添加图例:使用plt.legend函数添加图例。

  11. 显示图形:使用plt.show函数显示图形。

代码: 

  1. # -- coding: utf-8 --
  2. import numpy as np
  3. import matplotlib.pyplot as plt
  4. # 如果需要使用中文标签,还需添加以下代码
  5. plt.rcParams['font.sans-serif'] = ['SimHei'] # 指定默认字体为中文黑体
  6. # 数据
  7. data = [[0.40, 0.32, 0.35, 0.30, 0.30, 0.88],
  8. [0.85, 0.75, 0.30, 0.25, 0.20, 0.40],
  9. [0.43, 0.89, 0.30, 0.28, 0.22, 0.30],
  10. [0.20, 0.30, 0.85, 0.45, 0.32, 0.25],
  11. [0.19, 0.22, 0.40, 0.90, 0.92, 0.28],
  12. [0.62, 0.55, 0.27, 0.25, 0.35, 0.30]]
  13. # 角度(弧度)
  14. angles = np.linspace(0, 2*np.pi, 6, endpoint=False)
  15. # 重复第一个角度以使图像闭合
  16. angles = np.concatenate((angles, [angles[0]]))
  17. # 职业
  18. occupations = ['工程师', '实验员', '艺术家', '推销员', '记事员', '社会工作者', '技术员']
  19. # 绘图
  20. fig = plt.figure()
  21. ax = fig.add_subplot(111, polar=True)
  22. for i in range(len(data)):
  23. # 绘制折线图
  24. ax.plot(angles, data[i]+data[i][:1], 'o-', linewidth=2, label=occupations[i])
  25. # 填充颜色
  26. ax.fill(angles, data[i]+data[i][:1], alpha=0.25)
  27. # 添加坐标轴标签
  28. ax.set_thetagrids(angles*180/np.pi, occupations)
  29. # 添加标题
  30. plt.title('Holland Personality Analysis', fontsize=20)
  31. # 添加图例
  32. plt.legend(loc='best')
  33. # 显示图形
  34. plt.show()

效果:

 

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号