文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python绘制单数据系列柱状图、多数据系列柱状图、堆积柱状图、百分比堆积柱状图

2023-09-26 09:55

关注

1.单数据系列柱状图:

运行结果:

 具体代码:

#引入工具包import matplotlib.pyplot as pltimport numpy as np#设置中文字体,如果不需要中文,则可不写该语句plt.rcParams["font.sans-serif"]=["SimHei"]#写入数据x_data=['Fair', 'Good', 'Very Good', 'Premium', 'Ideal']y_data=[4300, 3800, 3950, 4700, 3500]#利用bar()函数设置柱状图的参数,plt.bar(x_data, y_data, width=0.5, color='red')plt.title('单数据系列柱状图')#设置中文标题plt.xlabel('Cut')#x轴的标签plt.ylabel('Price')#y轴的标签plt.show()#show()函数进行绘制

补充:

工具包matplotlib可直接在命令提示符中输入pip install matplotlib,回车进行下载;

工具包numpy可直接在命令提示符中输入pip install numpy,回车进行下载;

3.plt.bar(x,y,width=0.5,bottom=0.0,align='center',color='red',edgecolor='gray')函数的各项参数:

x

表示x坐标,数据类型为int或float类型,等间距排列;

y

表示y坐标,即柱状图的高度,数据类型为int或float类型;

width

表示柱状图的宽度,取值在0~1之间,默认为0.8;

bottom

柱状图的起始位置,也就是y轴的起始坐标;

align

柱状条的中心位置,默认"center"居中,可设置为"lege"边缘;

color

柱状条颜色;

edgecolor

柱状条边框颜色;

linewidth

柱状条边框宽度;

tick_label

下标标签;

orientation

柱状图是的竖直和水平,竖直条:“vertical”,水平条:“horizontal”;默认为竖直。

2.多数据系列柱状图:

运行结果:

具体代码:

#引用工具库import pandas as pd #使用该数据包导入数据表import numpy as npfrom matplotlib import pyplot as plt#引用中文plt.rcParams["font.sans-serif"]=["SimHei"]plt.rcParams['axes.unicode_minus'] = False #防止负号乱码,在此代码中可不用#导入打开数据表表df=pd.read_csv('D:\PYthon3-9-13\Data\MultiColumn_Data.csv')#数据条数x=np.arange(3)#获取数据y1=df['1996']y2=df['1997']#绘制柱状图,颜色为默认设置,柱柱状条宽0.3plt.bar(x, y1, 0.3, label='1996')#label为柱状图标签plt.bar(x+0.3, y2, 0.3, label='1997')#两个柱状条相邻,x坐标要加上0.3#为柱状条设置数值(即设置x轴的下标标签)tick_label=['Temporary Stream', 'Permanent Stream', 'Lake']plt.xticks(x+0.3/2,tick_label)#使两个柱状条的中心位于轴点上plt.legend()  #显示上面的labelplt.title('多数据系列柱状图')plt.show()

 补充:

数据表如下:

 3.堆积柱状图:

运行结果:

 具体代码:

#引用工具库import pandas as pdimport numpy as npfrom matplotlib import pyplot as plt#引用中文plt.rcParams["font.sans-serif"]=["SimHei"]#打开表df=pd.read_csv('D:\PYthon3-9-13\Data\StackedColumn_Data.csv')fig,ax = plt.subplots()#创建子图,参数均为默认 label = [i for i in df.columns[1:]]#获取每一列的第一个值,作为x轴的坐标标签y1 = df.iloc[0,1:].values #获取第0行各列数据的数据值,.values即获取数据值y2 = df.iloc[1,1:].valuesy3 = df.iloc[2,1:].valuesy4 = df.iloc[3,1:].valuesy5 = df.iloc[4,1:].values#ax即在子图中进行绘制 ax.bar(label, y1, width=.4, label='Fair',color='#FF7F50',ec='k',lw=.6)ax.bar(label, y2, width=.4,  bottom=y1, label='Good',color='#FF4500',ec='k',lw=.6)ax.bar(label, y3, width=.4,  bottom=y2+y1, label='Very Good',color='#DC143C',ec='k',lw=.6)ax.bar(label, y4, width=.4,  bottom=y3+y2+y1, label='Premium',color='#B22222',ec='k',lw=.6)ax.bar(label, y5, width=.4,  bottom=y4+y3+y2+y1, label='Ideal',color='#8B0000',ec='k',lw=.6)ax.set_ylim(0,14000) #根据数据表中的数据值,自设置y轴坐标值的限制范围ax.legend() #绘制显示各个y的标签#设置坐标轴的标签,字体大小设为13,用fontsize设置字体大小ax.set_ylabel('values',fontsize=13)ax.set_xlabel('columns',fontsize=13)plt.show()

补充:

数据表如下:

 对表中数据的获取,请看以下代码语句:

部分颜色表如下:

 4.百分比堆积柱状图:

运行结果:

 具体代码:

import numpy as npimport pandas as pdimport matplotlib.pyplot as pltimport matplotlib.patches as mpatchesimport matplotlib.ticker as mtickfrom matplotlib.ticker import PercentFormatter #引用包中的百分比函数plt.rcParams['font.sans-serif'] = ['SimHei']df=pd.read_csv('D:\PYthon3-9-13\Data\StackedColumn_Data.csv')#设置填充的颜色colors = ['#ADFEDC','#4EFEB3','#02F78E','#02CB74','#019858']#获取处理数据labels = [i for i in df.columns[1:]]y1 = df.iloc[0,1:].valuesy2 = df.iloc[1,1:].valuesy3 = df.iloc[2,1:].valuesy4 = df.iloc[3,1:].valuesy5 = df.iloc[4,1:].valuesdata = [y1,y2,y3,y4,y5] #为方便后续引用,将数据放入data中x = range(len(labels)) #将获取的labels依次给到x轴bottom_y = np.zeros(len(labels)) #将bottom_y元素都初始化为0data = np.array(data) #将data放入数组中sums = np.sum(data, axis=0) #求数组data的和,为计算百分比做准备j = 0figure, ax = plt.subplots() #创建子图,默认设置for i in data: #通过函数进行绘制图像    y = i / sums #获取各个y值的百分比    plt.bar(x, y, width=0.5, color=np.array(colors)[j], bottom=bottom_y, edgecolor='gray')    bottom_y = y + bottom_y #实现百分比柱状条的堆积    plt.xticks(x, labels) #设置x轴的坐标标签    legend_labels = ['Fair', 'Good', 'Very Good', 'Premium','Ideal']  #设置图像图例    color = ['#ADFEDC','#4EFEB3','#02F78E','#02CB74','#019858'] #给定与柱状条相同的颜色    #将颜色和图例标签对应起来    patches = [mpatches.Patch(color=color[h],label="{:s}".format(legend_labels[h])) for h in range(len(legend_labels))]    ax = plt.gca()#绘制子图    box = ax.get_position()    plt.gca().yaxis.set_major_formatter(PercentFormatter(1)) #纵轴设置为百分比    #生成legend,显示标签;用bbox_to_anchor=(1, 1)设置图例的位置    ax.legend(handles=patches,ncol=1, bbox_to_anchor=(1, 1))      figure.subplots_adjust(right=0.7)    j+=1 #color=np.array(colors)[j],通过数组给定柱状条相应的颜色for i in range(1, 11, 1):#绘制平行于x轴的虚线    plt.axhline(y=i/10, linestyle='dashed', color='black', linewidth=0.5)labels = ax.get_xticklabels() + ax.get_yticklabels()ax.set_title('百分比堆积柱状图',fontsize=13)ax.set_ylabel('values',fontsize=13)ax.set_xlabel('columns',fontsize=13)plt.show()

补充:

数据表如下:

注:如有不正确的或表述不当的请及时反馈,谢谢。

来源地址:https://blog.csdn.net/BlackYIYI/article/details/127997879

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯