找回密码
 会员注册
查看: 24|回复: 0

Python之Matplotlib柱状图(竖直柱状图和水平柱状图)、直方图和饼状图

[复制链接]

2

主题

0

回帖

7

积分

新手上路

积分
7
发表于 2024-9-6 15:14:34 | 显示全部楼层 |阅读模式
文章目录一、柱状图二、竖直柱状图1.基本的柱状图2.同位置多柱状图3.堆叠柱状图三、水平柱状图1.基本的柱状图2.同位置多柱状图3.堆叠柱状图四、直方图plt.hist()1.返回值2.添加折线直方图3.不等距分组4.多类型直方图5.堆叠直方图五、饼状图pie()1.百分比显示percentage2.饼状图的分离3.设置饼状图百分比和文本距离中心位置4.图例在开始,我们先引入matplotlib和numpy库。frommatplotlibimportpyplotaspltimportnumpyasnp12'运行运行对基本配置进行设置,将中文字体设置为黑体,不包含中文负号,分辨率为100,图像显示大小设置为(5,3)。plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus']=False​plt.rcParams['figure.dpi']=100​plt.rcParams['figure.figsize']=(5,3)1234一、柱状图柱状图是一种用矩形柱来表示数据分类的图表。柱状图可以垂直绘制,也可以水平绘制。它的高度与其所表示的数值成正比关系。柱状图显示了不同类别之间的比较关系,图表的水平轴X指定被比较的类别,垂直轴Y则表示具体的类别值二、竖直柱状图matplotlib.pyplot.bar(x,height,width:float=0.8,bottom=None,*,align:str=‘center’,data=None,**kwargs)1其参数具体如下含义:x表示x坐标,数据类型为float类型,一般是通过np.arange()生成的固定步长列表。height表示柱状图的高度,也就是y坐标值,数据类型为float类型,一般为一个列表,包含生成柱状图的所有y值。width表示柱状图的宽度,取值在0~1之间,默认值为0.8。bottom表示柱状图的起始位置,也就是y轴的起始坐标,默认值为None。align表示柱状图的中心位置,“center”,“lege”边缘,默认值为’center’。color表示柱状图颜色,默认为蓝色。alpha表示透明度,取值在0~1之间,默认值为1。label表示标签,设置后需要调用plt.legend()生成。edgecolor表示边框颜色(ec)。linewidth表示边框宽度,浮点数或类数组,默认为None(lw)。tick_label表示柱子的刻度标签,字符串或字符串列表,默认值为None。linestyle表示线条样式(ls)。1.基本的柱状图我们可以简单画一个柱状图用以观察,x轴数据通过range函数生成,y轴数据随便设定一个数组即可。importmatplotlib.pyplotaspltx=range(5)​data=[5,20,15,25,10]​plt.title("基本柱状图")plt.grid(ls="--",alpha=0.5)plt.bar(x,data)123456(1)bottom参数。bottom参数表示的是柱状图的起始位置,也就是y轴的起始坐标,默认值为None。我们仍采用和上述例子相同的数据,但与之不同的是,我们对y轴数据的起始点进行修改。这里需要注意的是,bottom参数设定的数组与y轴数据的参数是一一对应的,而且,两个数组的形状要相同。importmatplotlib.pyplotaspltx=range(5)​data=[5,20,15,25,10]​plt.title("基本柱状图")​plt.grid(ls="--",alpha=0.5)plt.bar(x,data,bottom=[10,20,5,0,10])123456(2)柱状图颜色。关于柱状图的颜色,我们也采用上述的数据进行操作,此时,不设置柱状图的bottom参数,同时,将柱状图的颜色设置为绿色。importmatplotlib.pyplotaspltx=range(5)data=[5,20,15,25,10]​plt.title("设置柱状图颜色")plt.grid(ls="--",alpha=0.5)​plt.bar(x,data,facecolor="green")#plt.bar(x,data,color="green")1234567那么,在某些特定的情况下,柱状图的单一颜色并不利于我们后续的观察,因此,我们可以使用facecolor函数,分别对每个柱状图进行颜色的设置。importmatplotlib.pyplotaspltx=range(5)data=[5,20,15,25,10]plt.title("color参数设置柱状图不同颜色")plt.grid(ls="--",alpha=0.5)plt.bar(x,data,color=['r','g','b'])123456'运行运行(3)柱状图描边。描边的相关的关键字参数为:edgecolor或ec。linestyle或ls。linewidth或lw。具体可见如下具体实例。importmatplotlib.pyplotasplt​data=[5,20,15,25,10]​plt.title("设置边缘线条样式")​plt.bar(range(len(data)),data,ec='r',ls='--',lw=2)12342.同位置多柱状图在同一个x轴位置绘制多个柱状图,主要是通过调整柱状图的宽度和每个柱状图x轴的起始位置。例如,我们有2022年冬奥会挪威、德国、中国、美国和瑞典的金银铜牌数和总奖牌数。对此,我们需要绘制如下图形:对该柱状图进行分析,可得:(1)本实例需要对x轴进行计算,因此需要将x轴转数值。(2)确定同一x轴中,每个柱状图x轴的起始位置。(3)需要设置图形的宽度。(4)图形2的起始位置=图形1起始位置+图形的宽度。(5)图形3的起始位置=图形1起始位置+2倍图形的宽度。(6)需要给每个柱状图循环显示文本内容。(7)需要显示图例。具体柱状图绘制过程如下:首先,我们需要导入国家和各个国家的金银铜奖牌数。countries=['挪威','德国','中国','美国','瑞典']gold_medal=[16,12,9,8,8]silver_medal=[8,10,4,10,5]bronze_medal=[13,5,2,7,5]1234'运行运行此时,如果我们直接进行绘制的话,会发现每个国家的奖牌柱状图发生了重叠,并且每个柱状图的宽度也过大。这是因为他们都默认y轴的起始坐标也就是bottom参数为0,宽度参数由于没有设置,默认是0.8。plt.bar(countries,gold_medal,color="gold")plt.bar(countries,silver_medal,color="silver")plt.bar(countries,bronze_medal,color="red")123针对上述在绘图过程当中出现的问题和最后结果的样图,我们需要将每个国家的金银铜牌柱状图分别画在一起,所以我们需要对x轴的国家参数进行坐标计算。由于字符串不可以直接进行算术运算,因此,我们使用np.arange将他们转化成数组,然后在返回字符串国家,并将柱状图的宽度width设置为0.2x=np.arange(len(countries))print(x)width=0.2#[01234]1234随后,我们确定每个国家的金银铜牌柱状图的起始位置。金牌呃起始位置就是每个国家对应的x数值,银牌的起始位置就是每个国家对应的x数值再加上金牌柱状图的宽度,铜牌的起始位置与银牌相似,加上两倍的金牌位置即可(这里我们将每个柱状图的宽度均设置为0.2)。gold_x=x​silver_x=x+width​bronze_x=x+2*width123在上述运行完成后,分别绘制图形即可。plt.bar(gold_x,gold_medal,width=width,color="gold")​plt.bar(silver_x,silver_medal,width=width,color="silver")​plt.bar(bronze_x,bronze_medal,width=width,color="saddlebrown")123此时,我们注意到,绘制柱状图的横坐标是数字还没有返回我们的国家参数。对此,我们需要将x轴的坐标变回来。plt.xticks(x+width,labels=countries)​1最后,我们显示出每一个柱状图的高度参数和图例,就得到了我们需要的图像。foriinrange(len(countries)):plt.text(gold_x[i],gold_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)plt.text(silver_x[i],silver_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)plt.text(bronze_x[i],bronze_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)plt.legend()12345代码汇总:#库导入frommatplotlibimportpyplotaspltimportnumpyasnp#参数设置plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus']=Falseplt.rcParams['figure.dpi']=100plt.rcParams['figure.figsize']=(5,3)#国家和奖牌数据导入countries=['挪威','德国','中国','美国','瑞典']gold_medal=[16,12,9,8,8]silver_medal=[8,10,4,10,5]bronze_medal=[13,5,2,7,5]#将横坐标国家转换为数值x=np.arange(len(countries))width=0.2#计算每一块的起始坐标gold_x=xsilver_x=x+widthbronze_x=x+2*width#绘图plt.bar(gold_x,gold_medal,width=width,color="gold",label="金牌")plt.bar(silver_x,silver_medal,width=width,color="silver",label="银牌")plt.bar(bronze_x,bronze_medal,width=width,color="saddlebrown",label="铜牌")#将横坐标数值转换为国家plt.xticks(x+width,labels=countries)#显示柱状图的高度文本foriinrange(len(countries)):plt.text(gold_x[i],gold_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)plt.text(silver_x[i],silver_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)plt.text(bronze_x[i],bronze_medal[i],gold_medal[i],va="bottom",ha="center",fontsize=8)#显示图例plt.legend(loc="upperright")1234567891011121314151617181920212223242526272829303132333435363738394041'运行运行其他知识点:在Matplotlib中旋转X轴刻度标签文本。(1)plt.xticks(rotation=)旋转Xticks标签文本。(2)fig.autofmt_xdate(rotation=)旋转Xticks标签文本。(3)ax.set_xticklabels(xlabels,rotation=)旋转Xticks标签文本。(4)plt.setp(ax.get_xticklabels(),rotation=)旋转Xticks标签文本。(5)ax.tick_params(axis=‘x’,labelrotation=)旋转Xticks标签文本。3.堆叠柱状图所谓堆叠柱状图就是将不同数组别的柱状图堆叠在一起,堆叠后的柱状图高度显示了两者相加的结果值。如图:对该图进行分析可得:(1)金牌榜的起始高度为:铜牌数据+银牌数据。(2)银牌榜的起始高度为:银牌高度。(3)铜牌榜的起始高度为:0。(4)起始位置的数据相加需要使用numpy的相关知识。(6)需要确定柱状图的颜色。(7)显示图例。具体的绘制办法,跟上一个同位置多柱状图是完全类似的,区别在于我们需要注意bottom的数值计算,同时,金银铜牌的起始坐标是完全相同的。#库导入frommatplotlibimportpyplotaspltimportnumpyasnp#参数设置plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus']=Falseplt.rcParams['figure.dpi']=100plt.rcParams['figure.figsize']=(5,3)#国家和奖牌数据输入、柱状图宽度设置countries=['挪威','德国','中国','美国','瑞典']gold_medal=np.array([16,12,9,8,8])silver_medal=np.array([8,10,4,10,5])bronze_medal=np.array([13,5,2,7,5])​width=0.3#绘图plt.bar(countries,gold_medal,color='gold',label='金牌',bottom=silver_medal+bronze_medal,width=width)plt.bar(countries,silver_medal,color='silver',label='银牌',bottom=bronze_medal,width=width)​plt.bar(countries,bronze_medal,color='#A0522D',label='铜牌',width=width)#设置y轴标签,图例和文本值​plt.ylabel('奖牌数')​plt.legend(loc='upperright')​foriinrange(len(countries)):max_y=bronze_medal[i]+silver_medal[i]+gold_medal[i]plt.text(countries[i],max_y,max_y,va="bottom",ha="center")​1234567891011121314151617181920212223242526272829​三、水平柱状图1.基本的柱状图通过调用Matplotlib中的barh()函数可以生成水平柱状图。barh()函数的用法与bar()函数的用法基本一样,只是在调用barh()函数时使用y参数传入y轴数据,使用width参数传入代表条柱宽度的数据。ha(horizontalalignment)控制文本的x位置参数表示文本边界框的左边,中间或右边。va(verticalalignment)控制文本的y位置参数表示文本边界框的底部,中心或顶部。plt.barh(y,width,height=0.8,left=None,*,align='center',**kwargs)1例如,我们以竖直柱状图当中的国家金牌数为例进行绘制。countries=['挪威','德国','中国','美国','瑞典']gold_medal=np.array([16,12,9,8,8])plt.barh(countries,width=gold_medal)1232.同位置多柱状图在同一个y轴位置绘制多个柱状图,主要是通过调整柱状图的宽度和每个柱状图y轴的起始位置。例如,我们有最近三天当中3部电影的票房变化的数据。movie=['新蝙蝠侠','狙击手','奇迹笨小孩']real_day1=[4053,2548,1543]real_day2=[7840,4013,2421]real_day3=[8080,3673,1342]1234'运行运行对此,我们需要绘制如下图像。对该图进行分析可得:(1)由于牵扯高度的计算,因此先将y轴转换为数值型。(2)需要设置同图形的高度。(3)计算每个图形高度的起始位置。(4)绘制图形。(5)替换y轴数据。由于牵扯计算,因此将数据转numpy数组,水平的用位置多柱状图绘制方法与竖直的完全相同,在此便不过多叙述了。#库导入frommatplotlibimportpyplotaspltimportnumpyasnp#参数设置plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus']=Falseplt.rcParams['figure.dpi']=100plt.rcParams['figure.figsize']=(5,3)#数据的输入movie=['新蝙蝠侠','狙击手','奇迹笨小孩']real_day1=np.array([4053,2548,1543])​real_day2=np.array([7840,4013,2421])​real_day3=np.array([8080,3673,1342])​​#y轴转换为数值型num_y=np.arange(len(movie))​#设置同图形的高度height=0.2​#计算每个图形高度的起始位置movie1_start_y=num_ymovie2_start_y=num_y+heightmovie3_start_y=num_y+2*height​​#绘制图形​plt.barh(movie1_start_y,real_day1,height=height)​plt.barh(movie2_start_y,real_day2,height=height)​plt.barh(movie3_start_y,real_day3,height=height)​#计算宽度值和y轴值,替换y轴数据​plt.yticks(num_y+height,movie)123456789101112131415161718192021222324252627282930313233343.堆叠柱状图水平的堆叠柱状图与竖直的堆叠柱状图类似都是将不同数组别的柱状图堆叠在一起,堆叠后的柱状图高度显示了两者相加的结果值。如图:对该图进行分析可得:(1)确定图形距离左侧的位置。(2)设置同一宽度。(3)绘制图形设置left参数。(4)标注数据。由于过程当中牵扯到计算,因此需要将数据转numpy数组。其他部分与绘制竖直堆叠柱状图的过程类似,在此便不过多进行叙述。#库导入frommatplotlibimportpyplotaspltimportnumpyasnp#参数设置plt.rcParams['font.sans-serif']=['SimHei']plt.rcParams['axes.unicode_minus']=Falseplt.rcParams['figure.dpi']=100plt.rcParams['figure.figsize']=(5,3)#数据的输入movie=['新蝙蝠侠','狙击手','奇迹笨小孩']real_day1=np.array([4053,2548,1543])real_day2=np.array([7840,4013,2421])real_day3=np.array([8080,3673,1342])​#确定距离左侧​left_day2=real_day1​left_day3=real_day1+real_day2​#设置线条高度height=0.2​#绘制图形:plt.barh(movie,real_day1,height=height)​plt.barh(movie,real_day2,left=left_day2,height=height)​plt.barh(movie,real_day3,left=left_day3,height=height)​#设置数值文本,计算宽度值和y轴为值​sum_data=real_day1+real_day2+real_day3foriinrange(len(movie)):plt.text(sum_data[i],movie[i],sum_data[i],va="center",ha="left")1234567891011121314151617181920212223242526272829303132四、直方图plt.hist()直方图(Histogram),又称质量分布图,它是一种条形图的一种,由一系列高度不等的纵向线段来表示数据分布的情况。直方图的横轴表示数据类型,纵轴表示分布情况。柱状图和直方图的区别:直方图用于概率分布,它显示了一组数值序列在给定的数值范围内出现的概率。柱状图则用于展示各个类别的频数。柱状图直方图柱状图一般用于描述离散型分类数据的对比直方图一般用于描述连续型数据的分布关系每根柱子宽度固定,柱子之间会有间距每根柱子宽度可以不一样,且一般没有间距横轴变量可以任意排序横轴变量有一定顺序规则将统计值的范围分段,即将整个值的范围分成一系列间隔,然后计算每个间隔中有多少值。直方图也可以被归一化以显示相对频率。然后,它显示了属于几个类别中的每个类别的占比,其高度总和等于1。其语法模板如下:plt.hist(x,bins=None,range=None,density=None,weights=None,cumulative=False,bottom=None,histtype='bar',align='mid',orientation='vertical',rwidth=None,log=False,color=None,label=None,stacked=False,normed=None,*,data=None,**kwargs)1其参数具体如下含义:x:作直方图所要用的数据,必须是一维数组;多维数组可以先进行扁平化再作图;必选参数。bins:直方图的柱数,即要分的组数,默认为10。weights:与x形状相同的权重数组;将x中的每个元素乘以对应权重值再计数;如果normed或density取值为True,则会对权重进行归一化处理。这个参数可用于绘制已合并的数据的直方图。density:布尔,可选。如果为True,返回元组的第一个元素将会将计数标准化以形成一个概率密度,也就是说,直方图下的面积(或积分)总和为1。这是通过将计数除以数字的数量来实现的观察乘以箱子的宽度而不是除以总数数量的观察。如果叠加也是真实的,那么柱状图被规范化为1(替代normed)。bottom:数组,标量值或None;每个柱子底部相对于y=0的位置。如果是标量值,则每个柱子相对于y=0向上/向下的偏移量相同。如果是数组,则根据数组元素取值移动对应的柱子;即直方图上下便宜距离。histtype:{‘bar’,‘barstacked’,‘step’,‘stepfilled’};bar是传统的条形直方图;barstacked是堆叠的条形直方图;step是未填充的条形直方图,只有外边框;stepfilled是有填充的直方图;当histtype取值为step或stepfilled,rwidth设置失效,即不能指定柱子之间的间隔,默认连接在一起。align:{‘left’,‘mid’,‘right’};left是柱子的中心位于bins的左边缘;mid是柱子位于bins左右边缘之间;right是柱子的中心位于bins的右边缘。color:具体颜色,数组(元素为颜色)或None。label:字符串(序列)或None;有多个数据集时,用label参数做标注区分。normed:是否将得到的直方图向量归一化,即显示占比,默认为0,不归一化;不推荐使用,建议改用density参数。edgecolor:直方图边框颜色。alpha:透明度。例如,我们可以使用np.random.randint随机生成300个在区间[140,180](不包含180)随机数据。x_value=np.random.randint(140,180,300)plt.hist(x_value,bins=10,edgecolor='white')plt.title("数据统计")plt.xlabel("身高")plt.ylabel("比率")123451.返回值n:数组或数组列表,返回直方图的值。bins:数组,返回各个bin的区间范围。patches:列表的列表或列表,返回每个bin里面包含的数据,是一个list。以上个例子进行试验,分别对num,bins和patches的返回值进行观察。num#array([25.,28.,34.,39.,29.,25.,37.,34.,26.,23.])bins_limit#array([140.,143.9,147.8,151.7,155.6,159.5,163.4,167.3,171.2,#175.1,179.])foriinpatches:print(i)print(i.get_x())print(i.get_y())print(i.get_height())print(i.get_width())12345678910111213patches[0].get_width()#3.900000000000005712知识点补充:xy:xy位置(x取值bins_limits是分组时的分隔值,y取值都是0开始)。width:宽度为各个bin的区间范围(bins_limits是分组时的分隔值)。height:高度也就是密度值(n是分组区间对应的频率)。angle:角度。以最开始的直方图为例,进行上述参数的观察。2.添加折线直方图在直方图中,我们也可以加一个折线图,辅助我们查看数据变化情况。首先通过pyplot.subplots()创建Axes对象。通过Axes对象调用hist()方法绘制直方图,返回折线图所需要的下x,y数据。然后Axes对象调用plot()绘制折线图。我们对前面的代码进行修改即可。#创建一个画布fig,ax=plt.subplots()​#绘制直方图num,bins_limit,patches=ax.hist(x_value,bins=10,edgecolor='white')​#注意num返回的个数是10,bins_limit返回的个数为11,需要截取print(bins_limit[:-1])#曲线图ax.plot(bins_limit[:10],num,'--',marker="o")plt.xticks(bins_limit,rotation=45)1234567891011123.不等距分组面的直方图都是等距的,但有时我们需要得到不等距的直方图,这个时候只需要确定分组上下限,并指定histtype=“bar”就可以。fig,ax=plt.subplots()x=np.random.normal(100,20,100)bins=[50,60,70,90,100,110,140,150]ax.hist(x,bins,color="g",rwidth=0.5)ax.set_title('不等距分组')plt.show()1234564.多类型直方图我们在使用直方图查查看数据的频率时,有时候会查看多种类型数据出现的频率。这时候我们可以以列表的形式传入多种数据给hist()方法的x数据。我们指定10个分组个数,每组有ABC三类,分别生成10000,5000,2000个值,实际绘图代码与单类型直方图差异不大,只是增加了一个图例项,在ax.hist函数中先指定图例label名称。n_bins=10​fig,ax=plt.subplots(figsize=(8,5))​x_multi=[np.random.randn(n)fornin[10000,5000,2000]]​ax.hist(x_multi,n_bins,histtype='bar',label=list("ABC"))​ax.set_title('多类型直方图')​ax.legend()1234565.堆叠直方图我们有时候会对吧同样数据范围情况下,对比两组不同对象群体收集的数据差异。对此,我们准备两组数据:x_value=np.random.randint(140,180,200)x2_value=np.random.randint(140,180,200)12直方图属性data:以列表的形式传入两组数据。设置直方图stacked:为True,允许数据覆盖。plt.hist([x_value,x2_value],bins=10,stacked=True)#([array([16.,23.,27.,22.,13.,22.,18.,21.,18.,20.]),#array([39.,46.,44.,35.,33.,47.,41.,42.,33.,40.])],#array([140.,143.9,147.8,151.7,155.6,159.5,163.4,167.3,171.2,#175.1,179.]),12345​五、饼状图pie()饼状图用来显示一个数据系列,具体来说,饼状图显示一个数据系列中各项目的占项目总和的百分比。Matplotlib提供了一个pie()函数,该函数可以生成数组中数据的饼状图。您可使用x/sum(x)来计算各个扇形区域占饼图总和的百分比。pie()函数的语法模板如下:pyplot.pie(x,explode=None,labels=None,colors=None,autopct=None)1pie()函数的参数说明如下:x:数组序列,数组元素对应扇形区域的数量大小。labels:列表字符串序列,为每个扇形区域备注一个标签名字。colors:为每个扇形区域设置颜色,默认按照颜色周期自动设置。autopct:格式化字符串“fmt%pct”,使用百分比的格式设置每个扇形区的标签,并将其放置在扇形区内。pctdistance:设置百分比标签与圆心的距离。labeldistance:设置各扇形标签(图例)与圆心的距离。explode:指定饼图某些部分的突出显示,即呈现爆炸式。shadow:是否添加饼图的阴影效果。例如,我们将大小设置为(5,5),定义饼的标签,每个标签所占的数量,绘制饼图。plt.rcParams['figure.figsize']=(5,5)labels=['娱乐','育儿','饮食','房贷','交通','其它']​x=[200,500,1200,7000,200,900]​plt.pie(x,labels=labels)#[Text(1.09783,0.0690696,'娱乐'),#Text(1.05632,0.30689,'育儿'),#Text(0.753002,0.801865,'饮食'),#Text(-1.06544,-0.273559,'房贷'),#Text(0.889919,-0.646564,'交通'),#Text(1.05632,-0.30689,'其它')])123456789101.百分比显示percentageautopct:格式化字符串。我们定义饼的标签,每个标签所占的数量,%.2f%%显示百分比,保留2位小数。labels=['娱乐','育儿','饮食','房贷','交通','其它']​x=[200,500,1200,7000,200,900]​plt.title("饼图示例-8月份家庭支出")​plt.pie(x,labels=labels,autopct='%.2f%%')#[Text(1.09783,0.0690696,'娱乐'),#Text(1.05632,0.30689,'育儿'),#Text(0.753002,0.801865,'饮食'),#Text(-1.06544,-0.273559,'房贷'),#Text(0.889919,-0.646564,'交通'),#Text(1.05632,-0.30689,'其它')],#[Text(0.598816,0.0376743,'2.00%'),#Text(0.576176,0.167395,'5.00%'),#Text(0.410728,0.437381,'12.00%'),#Text(-0.58115,-0.149214,'70.00%'),#Text(0.48541,-0.352671,'2.00%'),#Text(0.576176,-0.167395,'9.00%')])123456789101112131415162.饼状图的分离explode:指定饼图某些部分的突出显示。我们定义饼的标签,每个标签所占的数量,%.2f%%显示百分比,保留2位小数。labels=['娱乐','育儿','饮食','房贷','交通','其它']x=[200,500,1200,7000,200,900]​explode=(0.03,0.05,0.06,0.04,0.08,0.21)​plt.pie(x,labels=labels,autopct='%3.2f%%',explode=explode)12343.设置饼状图百分比和文本距离中心位置pctdistance:设置百分比标签与圆心的距离。labeldistance:设置各扇形标签(图例)与圆心的距离。labels=['娱乐','育儿','饮食','房贷','交通','其它']​x=[200,500,1200,7000,200,900]​explode=(0.03,0.05,0.06,0.04,0.08,0.1)​plt.pie(x,labels=labels,autopct='%3.2f%%',explode=explode,labeldistance=1.35,pctdistance=1.2)12344.图例labels=['娱乐','育儿','饮食','房贷','交通','其它']​x=[200,500,1200,7000,200,900]​explode=(0.03,0.05,0.06,0.04,0.08,0.1)​plt.pie(x,labels=labels,autopct='%3.2f%%',explode=explode,labeldistance=1.35,pctdistance=1.2)plt.legend()12345可以通过设置x,y的刻度一样,使其饼图为正圆plt.axis(‘equal’)。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

QQ|手机版|心飞设计-版权所有:微度网络信息技术服务中心 ( 鲁ICP备17032091号-12 )|网站地图

GMT+8, 2025-1-11 17:12 , Processed in 0.442648 second(s), 26 queries .

Powered by Discuz! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表