前两篇文章介绍了几种常见的条形图,实际上看起来简单的条形图可探索的设置还有很多!在体育赛事中,经常出现一种对称条形图,比如对比两个热门选手或者队伍在各方面的打分情况等,这也是在普通横向条形图的基础上绘制出来的,作为无所不能的python,当然也是可以绘制这种图形的!
闲话少叙,直接上代码吧!
df = pd.read_excel(r"D:\data\football\曼城vs利物浦.xlsx") df
这是从英超历年球队积分的数据中截取出来的曼城和利物浦两支球队的数据,制作一个对称条形图,查看这两只球队在2010–2019年的积分表现。
这是原数据,单看表格对比不是很明显,来画一个对称条形图试试看:
plt.figure(figsize=(10,6)) ax = plt.gca() #获取坐标轴对象 ax.spines['right'].set_color('none') #把右边的边框颜色设置为无色,隐藏右边框 ax.spines['top'].set_color('none') #把上边的边框颜色设置为无色,隐藏上边框 ax.spines['bottom'].set_color('none') #把上边的边框颜色设置为无色,隐藏上边框 ax.yaxis.set_ticks_position('left') #指定左边的边为 y 轴 ax.spines['left'].set_position(('data', 0)) #指定 data 设置的left(也就是指定的y轴)绑定到x轴的0这个点上 plt.xticks([]) #去掉x轴刻度 plt.yticks(df.iloc[:,0].tolist()) #设置y轴刻度为年份 #绘制利物浦队的条形图,颜色用默认的蓝色 plt.barh(df.iloc[:,0],df.iloc[:,1], height=0.5,label = "利物浦") #绘制曼城队的条形图,需要在y轴的两侧显示条形,所以曼城队的数据取负数,设置颜色为粉色 plt.barh(df.iloc[:,0],-df.iloc[:,2],height=0.5,label = "曼城",color = "pink") #通过循环为曼城队的每个横向条形加标签,标签位置在对应条形的顶端,内容为球队当年的积分 for i,j in zip(range(len(df)),[2010,2011,2012,2013,2014,2015,2016,2017,2018,2019]): plt.text(-df.iloc[:,2][i]-5,j,df.iloc[:,2][i]) #通过循环为利物浦队的每个横向条形加标签,标签位置在对应条形的顶端,内容为球队当年的积分 for i,j in zip(range(len(df)),[2010,2011,2012,2013,2014,2015,2016,2017,2018,2019]): plt.text(df.iloc[:,1][i]+1,j,df.iloc[:,1][i]) plt.legend(loc = 4); #显示图例,loc参数指定图例位置在右下角
请看效果图:
是不是比看上边的表格要清晰和容易多了,一眼就能看出每一年两个球队的积分对比情况,整体看来曼城队是强于利物浦队的,至于那个异常的2019年数据,不是全年的数据,所以和其他年份数据差异很大。
对称条形图一般只能对比两个个体之间的各项指标数据,如果涉及多个个体,对称条形图就不怎么好用了。有另一种图可以同时展示多个个体的情况,就是发散型条形图!但是它本身也是有限制的,发散型条形图只能展示在某一个指标上多个个体的不同,而对称条形图是展示两个个体在多个指标上的对比,所以在实际应用中需要区分好需要实现的是什么。
到底是什么样的情况,我们还是直接上代码看图片吧:
df_yc = pd.read_excel(r"D:\data\football\球队排名比分2019.xlsx") df_yc.head(10) #查看前十条数据
这是英超2019年个球队的积分数据:
这是所有球队中在2019年积分排名前十的球队信息,绘图的时候所有球队的数据都会包含。
虽然发散型条形图形式和对称条形图类似,条形都是像两个互为相反的方向延申,然而两者还是有一些不同,对称条形图直接在其中一类数据直接取负数,而发散型条形图是在所有数据上都减掉了整体数据的均值,这样大于均值的数据依然为正,而低于均值的数据就会变成负数:
df_yc.积分.mean() #求所有球队的平均积分 df_yc.积分 = df_yc.积分 - df_yc.积分.mean() #所有球队的积分减掉均值 df_yc.sort_values("积分", inplace=True) #依据减掉均值后的积分进行升序排序 df_yc.head(10) #查看最新的前十条数据
由于条形图在绘制过程中是先从最下边开始画,我们希望最小的数值被画在最下边,由下到上升序排序,所以原数据要进行升序排序。
到这里其实什么都不用设置就可以直接出图了(做个心理建设,直接出的图有点丑):
plt.barh(y =df_yc.iloc[:,0],width=df_yc.iloc[:,1],height=0.3 ,color = colors,alpha=0.5);
是不是和曾经见过的发散型条形图长的差不多,除了丑一点。下边来进行一些完善,美化图形。
完善后的代码可就多了很多呢,具体如下:
plt.figure(figsize=(12,8)) #新建画布,尺寸为12*8 colors = [] #指定条形颜色 for i in df_yc.iloc[:,1]: if i > 0: colors.append("g") #超过均值的数值为绿色 else: colors.append("r") #低于均值的数值为红色 #绘制横向条形图,设置条形透明度为0.5,降低色彩饱和度,看起来更舒服一些 plt.barh(y =df_yc.iloc[:,0],width=df_yc.iloc[:,1],height=0.3 ,color = colors,alpha=0.5) pos = [] #指定要添加文本的x轴位置 for i in df_yc.iloc[:,1]: if i > 0: pos.append(i+0.5) #如果数值高于均值,文本在x轴的位置超过条形顶端0.5的距离 else: pos.append(i- 0.5)#如果数值低于均值,文本在x轴的位置小于条形顶端0.5的距离 for i in range(len(df_yc)): #通过循环为每个条形添加标签值 if pos[i] > 0: #plt.text(x轴方向位置,y轴方向位置,添加的文本信息) plt.text(x = pos[i]+0.5,y = i,s = round(df_yc.iloc[:,1].iloc[i],2)) else: plt.text(x = pos[i]-2,y = i,s = round(df_yc.iloc[:,1].iloc[i],2)) plt.title("2019英超各球队积分排名图(积分均值为30.25)") plt.grid(linestyle='--', alpha=0.5); #配置网格线
效果图:
是不是好看了很多,其实就是设置了画布大小,让整个图看起来不那么局促;然后控制条形的上下宽度,再加上标签方便查看每个条形的数据以及加了网格线,看起来就高大上了许多。
这个图很明显能看出英超球队积分参差不齐,没过均线的球队数量几乎是均线上球队数量的两倍,这也说明了好的球队特别好,把均线拉高了,差的球队数量很多,但是水平倒没有差的太离谱;整体来说还是好的球队更厉害,最好的超均线30分,最差的球队也只低于均线16分。
(本人一点都不懂足球,仅仅从2019年的数据中得到的一点点分析结果,之所以选择英超数据单纯的因为体育数据更容易得到一点而已,所以如果分析的不好,还请轻拍。)
数据分析咨询请扫描二维码
《Python数据分析极简入门》 第2节 5 Pandas数学计算 importpandasaspdd=np.array([[81,&n ...
2024-11-23数据分析涉及多个方面的学习,包括理论知识和实践技能。以下是数据分析需要学习的主要方面: 基础知识: 数据分析的基本概念 ...
2024-11-22数据分析适合在多个单位工作,包括但不限于以下领域: 金融行业:金融行业对数据分析人才的需求非常大,数据分析师可以从事经 ...
2024-11-22数据分析是一种涉及从大量数据中提取有用信息和洞察力的过程。其工作内容主要包括以下几个方面: 数据收集与整理:数据分析师 ...
2024-11-22数据分析师需要掌握多种技能,以确保能够有效地处理和分析数据,并为业务决策提供支持。以下是数据分析师需要掌握的主要技能: ...
2024-11-22数据开发和数据分析是两个密切相关但又有所区别的领域。以下是它们的主要区别: 定义和目标: 数据开发:数据开发涉及数据的 ...
2024-11-22数据架构师是负责设计和管理企业数据架构的关键角色,其职责涵盖了多个方面,包括数据治理、数据模型设计、数据仓库构建、数据安 ...
2024-11-22数据分析师需要具备一系列技能,以确保能够有效地处理、分析和解释数据,从而支持决策制定。以下是数据分析师所需的关键技能: ...
2024-11-22数据分析师需要具备一系列技能,以确保能够有效地处理、分析和解释数据,从而支持决策制定。以下是数据分析师所需的关键技能: ...
2024-11-22数据分析师需要具备一系列的技能和能力,以确保能够有效地处理、分析和解释数据,从而支持业务决策。以下是数据分析师所需的主要 ...
2024-11-22需求持续增长 - 未来数据分析师需求将持续上升,企业对数据驱动决策的依赖加深。 - 预测到2025年,中国将需要高达220万的数据人 ...
2024-11-22《Python数据分析极简入门》 第2节 4 Pandas条件查询 在pandas中,可以使用条件筛选来选择满足特定条件的数据 importpanda ...
2024-11-22数据分析师的工作内容涉及多个方面,主要包括数据的收集、整理、分析和可视化,以支持商业决策和问题解决。以下是数据分析师的一 ...
2024-11-21数据分析师必须掌握的技能可以从多个方面进行归纳和总结。以下是数据分析师需要具备的主要技能: 统计学基础:数据分析师需要 ...
2024-11-21数据分析入门的难易程度因人而异,总体来看,入门并不算特别困难,但需要一定的学习和实践积累。 入门难度:数据分析入门相对 ...
2024-11-21数据分析是一项通过收集、整理和解释数据来发现有用信息的过程,它在现代社会中具有广泛的应用和重要性。数据分析能够帮助人们更 ...
2024-11-21数据分析行业正在迅速发展,随着技术的不断进步和数据量的爆炸式增长,企业对数据分析人才的需求也与日俱增。本文将探讨数据分析 ...
2024-11-21数据分析的常用方法包括多种技术,每种方法都有其特定的应用场景和优势。以下是几种常见的数据分析方法: 对比分析法:通过比 ...
2024-11-21企业数字化转型是指企业利用数字技术对其业务进行改造和升级,以实现提高效率、降低成本、创新业务模式等目标的过程。这一过程不 ...
2024-11-21数据分析作为一个备受追捧的职业领域,吸引着越来越多的女性加入其中。对于女生而言,在选择成为一名数据分析师时,行业选择至关 ...
2024-11-21