zoukankan      html  css  js  c++  java
  • Matplotlib学习---用matplotlib画雷达图(radar chart)

    雷达图常用于对多项指标的全面分析。例如:HR想要比较两个应聘者的综合素质,用雷达图分别画出来,就可以进行直观的比较。

    用Matplotlib画雷达图需要使用极坐标体系,可点击此链接,查看对极坐标体系的介绍:https://www.cnblogs.com/kallan/p/6738577.html

    下面,我们从五个方面(编程能力,沟通技能,专业知识,团队协作,工具掌握)来对路人甲和路人乙进行比较。

    代码如下:

    import numpy as np
    from matplotlib import pyplot as plt
    fig=plt.figure(figsize=(10,5))
    ax1=fig.add_subplot(1,2,1,polar=True) #设置第一个坐标轴为极坐标体系
    ax2=fig.add_subplot(1,2,2,polar=True) #设置第二个坐标轴为极坐标体系
    fig.subplots_adjust(wspace=0.4) #设置子图间的间距,为子图宽度的40%
    
    p1={"编程能力":60,"沟通技能":70,"专业知识":65,"团体协作":75,"工具掌握":80} #创建第一个人的数据
    p2={"编程能力":70,"沟通技能":60,"专业知识":75,"团体协作":65,"工具掌握":70} #创建第二个人的数据
    
    data1=np.array([i for i in p1.values()]).astype(int) #提取第一个人的信息
    data2=np.array([i for i in p2.values()]).astype(int) #提取第二个人的信息
    label=np.array([j for j in p1.keys()]) #提取标签
    
    angle = np.linspace(0, 2*np.pi, len(data1), endpoint=False) #data里有几个数据,就把整圆360°分成几份
    angles = np.concatenate((angle, [angle[0]])) #增加第一个angle到所有angle里,以实现闭合
    data1 = np.concatenate((data1, [data1[0]])) #增加第一个人的第一个data到第一个人所有的data里,以实现闭合
    data2 = np.concatenate((data2, [data2[0]])) #增加第二个人的第一个data到第二个人所有的data里,以实现闭合
    
    #设置第一个坐标轴
    ax1.set_thetagrids(angles*180/np.pi, label, fontproperties="Microsoft Yahei") #设置网格标签
    ax1.plot(angles,data1,"o-")
    ax1.set_theta_zero_location('NW') #设置极坐标0°位置
    ax1.set_rlim(0,100) #设置显示的极径范围
    ax1.fill(angles,data1,facecolor='g', alpha=0.2) #填充颜色
    ax1.set_rlabel_position('255') #设置极径标签位置
    ax1.set_title("路人甲",fontproperties="SimHei",fontsize=16) #设置标题
    
    #设置第二个坐标轴
    ax2.set_thetagrids(angles*180/np.pi, label, fontproperties="Microsoft Yahei") #设置网格标签
    ax2.plot(angles,data2,"o-")
    ax2.set_theta_zero_location('NW') #设置极坐标0°位置
    ax2.set_rlim(0,100) #设置显示的极径范围
    ax2.fill(angles,data2,facecolor='g', alpha=0.2) #填充颜色
    ax2.set_rlabel_position('255') #设置极径标签位置
    ax2.set_title("路人乙",fontproperties="SimHei",fontsize=16) #设置标题
    
    plt.show()

    图像如下:

  • 相关阅读:
    LeetCode算法题-Find Mode in Binary Search Tree(Java实现)
    LeetCode算法题-Keyboard Row(Java实现)
    LeetCode算法题-Next Greater Element I(Java实现)
    LeetCode算法题-Construct the Rectangle(Java实现)
    月经贴之 适配器 UML 类图 描述
    最近准备面试 ,要求立即各种设计模式
    URL方案最佳做法|高级路由特性 | 精通ASP-NET-MVC-5-弗瑞曼
    使用属性创建区域 (Creating Areas with Attributes) | 使用区域 | 高级路由特性 | 精通ASP-NET-MVC-5-弗瑞曼
    iOS定位
    iOS本地化
  • 原文地址:https://www.cnblogs.com/HuZihu/p/9481081.html
Copyright © 2011-2022 走看看