Python绘制柱状图堆叠图完整代码

 更新时间:2023年09月20日 11:17:42   作者:项目申报小狂人  
有个朋友要求帮忙绘制堆叠柱状图,查阅了一些文档之后也算是完成了,只是一个小demo,下面我就记录一下,这篇文章主要给大家介绍了关于Python绘制柱状图堆叠图的相关资料,需要的朋友可以参考下

一、引入库

import matplotlib.pyplot as plt
import numpy as np

二、数据准备

示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。

开始绘制柱状堆叠图之前,我们需要生成实验数据。在本案例中,我们可以使用 NumPy 库生成两个数组 y1 和 y2 来分别表示产品 A 和 B 在五个不同城市的销售情况。代码如下:

import numpy as np
# 生成实验数据
x = np.array(['A', 'B', 'C', 'D', 'E'])
y1 = np.array([12, 25, 19, 23, 20])
y2 = np.array([15, 24, 25, 18, 20])

三、绘制基本柱状堆叠图

1.绘制基本图形

使用 Matplotlib 的 bar 函数来绘制柱状堆叠图。该函数需要传入以下参数:

  • left:每个矩形条左边的位置;
  • height:每个矩形条的高度;
  • bottom:每个矩形条底边的位置,即前面一个矩形条顶部的位置;
  • width:每个矩形条的宽度,该值默认为 0.8。

使用两个数组 y1 和 y2 分别表示产品 A 和 B 在五个城市的销售情况,使用 x 数组表示各城市名称。我们先定义一个关于柱状图的绘制参数,代码如下:

# 设置字体样式和大小
font={'family':'Times New Roman','size':28}
font_value = {'family':'Times New Roman','size':20}
# 绘制柱状堆叠图,设置柱子颜色和标签
fig, ax = plt.subplots(figsize=(12, 8))
N = len(y1)
width = 0.45
ind = np.arange(N)
bar_plot1 = ax.bar(ind, y1, width, color=plt.cm.Set1(np.arange(N)), alpha=0.7, label='Type A')
bar_plot2 = ax.bar(ind, y2, width, bottom=y1, color=plt.cm.Set2(np.arange(N)), alpha=0.7, label='Type B')

2.设置柱子宽度、添加刻度标签和旋转角度

调整柱子的宽度,使它们之间的距离更大,以便更清晰地区分每个城市的销售情况。

可以使用 width 参数来调整柱子的宽度,例如 width=0.4。此外,我们还需要为横坐标轴添加刻度标签,并将标签旋转 45 度,以便更清晰地显示每个城市的名称。代码如下:

# 设置字体样式和大小
font={'family':'Times New Roman','size':28}
font_value = {'family':'Times New Roman','size':20}
# 绘制柱状堆叠图,设置柱子颜色和标签
fig, ax = plt.subplots(figsize=(12, 8))
N = len(y1)
width = 0.45
ind = np.arange(N)
bar_plot1 = ax.bar(ind, y1, width, color=plt.cm.Set1(np.arange(N)), alpha=0.7, label='Type A')
bar_plot2 = ax.bar(ind, y2, width, bottom=y1, color=plt.cm.Set2(np.arange(N)), alpha=0.7, label='Type B')
# 添加标题、标签和图例
ax.set_title('Sales of Product A & B in Different Cities', fontsize=24)
ax.set_xlabel('City', font)
ax.set_ylabel('Value', font)
ax.legend(ncol=2, loc='best', fontsize=20)
# 设置横坐标轴刻度标签旋转角度
new_x = ['City '+i for i in x]
plt.xticks(np.arange(len(x)), new_x, rotation=45)
# 显示图表
plt.show()

四、完整代码

import matplotlib.pyplot as plt
import numpy as np
# 生成实验数据
x = np.array(['A', 'B', 'C', 'D', 'E'])
y1 = np.array([12, 25, 19, 23, 20])
y2 = np.array([15, 24, 25, 18, 20])
# 设置字体样式和大小
font={'family':'Times New Roman','size':28}
font_value = {'family':'Times New Roman','size':2}
# 绘制柱状堆叠图,设置柱子颜色和标签
fig, ax = plt.subplots(figsize=(12, 8))
#定义绘图的柱子组数
N = len(x)
###设置柱子宽度
width = 0.45
ind = np.arange(N)
bar_plot1 = ax.bar(ind, y1, width, color=plt.cm.Set1(np.arange(N)), alpha=0.7, label='Type A')
bar_plot2 = ax.bar(ind, y2, width, bottom=y1, color=plt.cm.Set2(np.arange(N)), alpha=0.7, label='Type B')
# bar_plot3 = bar_plot2+bar_plot
# 添加标题、标签和图例
# ax.set_title('Temperature / ℃', fontsize=24)
ax.set_xlabel('City', font)
ax.set_ylabel('Value', font)
ax.legend(ncol=2, loc='best', fontsize=20)
ax.set_ylim(0,53)
##x轴刻度名称、倾斜角度
new_x = ['City '+i for i in x]
plt.xticks(np.arange(len(x)), new_x, rotation=45)
# 设置坐标轴刻度字体和字号
font_tick = {'family': 'Times New Roman', 'size': 24}
for label in ax.get_xticklabels() + ax.get_yticklabels():
    label.set_fontproperties(font_tick)
# 调整字体颜色、柱子宽度等其他参数
for rect, height_1, height_2 in zip(bar_plot2, y1, y2):
    height_2 = rect.get_height()
    ax.text(rect.get_x() + rect.get_width()/2., height_1 + height_2 + 0.5, '%d' % int(height_2),
            ha='center', va='bottom', fontsize=20, color='green', fontname='Times New Roman')
    ax.text(rect.get_x() + rect.get_width()/2., height_1 + 1/2, '%d' % int(height_1),
            ha='center', va='bottom', fontsize=20, color='blue', fontname='Times New Roman')
##右上边框是否可见
# ax.spines['top'].set_visible(False)
# ax.spines['right'].set_visible(False)
##刻度线长宽设置
ax.tick_params(axis='x', direction='out', length=6, width=2)
ax.tick_params(axis='y', direction='in', length=6, width=2)
plt.tight_layout()
plt.savefig("C:/Users/ypzhao/Desktop/a.jpg",dpi=600)
# 显示图表
plt.show()

五、运行结果

总结

到此这篇关于Python绘制柱状图堆叠图的文章就介绍到这了,更多相关Python绘制柱状图堆叠图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python并发编程协程(Coroutine)之Gevent详解

    Python并发编程协程(Coroutine)之Gevent详解

    这篇文章主要介绍了Python并发编程协程(Coroutine)之Gevent详解,具有一定借鉴价值,需要的朋友可以参考下
    2017-12-12
  • Python中的列表及其操作方法

    Python中的列表及其操作方法

    这篇文章主要介绍了Python中的列表及其操作方法,涉及到的方法包括对列表元素进行修改、添加、删除、排序以及求列表长度等,此外还介绍了列表的遍历、数值列表、切片和元组的一些操作,下文详细介绍需要的小伙伴可以参考一下
    2022-03-03
  • windows下python安装paramiko模块和pycrypto模块(简单三步)

    windows下python安装paramiko模块和pycrypto模块(简单三步)

    这篇文章主要给大家介绍了通过简单的三个步骤在windows下python中安装paramiko模块和pycrypto模块的相关资料,文中安装的步骤,简单而且又易于大家理解,需要的朋友们下面跟着小编一起来学习学习吧。
    2017-07-07
  • python 每天如何定时启动爬虫任务(实现方法分享)

    python 每天如何定时启动爬虫任务(实现方法分享)

    python 每天如何定时启动爬虫任务?今天小编就为大家分享一篇python 实现每天定时启动爬虫任务的方法。具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-05-05
  • Python神器之Pampy模式匹配库的用法详解

    Python神器之Pampy模式匹配库的用法详解

    Pampy是Python的一个模式匹配类库,一个只有150行的类库,该库优雅、高效值得广大Python的码农加入自己基本开发栈中。本文就来讲讲Pampy的用法,需要的可以参考一下
    2022-07-07
  • numpy的Fancy Indexing和array比较详解

    numpy的Fancy Indexing和array比较详解

    这篇文章主要介绍了numpy的Fancy Indexing和array比较详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-06-06
  • Python Traceback异常代码排错利器使用指南

    Python Traceback异常代码排错利器使用指南

    这篇文章主要为大家介绍了Python Traceback异常代码排错利器使用指南,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2024-01-01
  • opencv检测动态物体的实现

    opencv检测动态物体的实现

    本文主要介绍了opencv检测动态物体的实现,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2021-07-07
  • Jupyter打开图形界面并画出正弦函数图像实例

    Jupyter打开图形界面并画出正弦函数图像实例

    这篇文章主要介绍了Jupyter打开图形界面并画出正弦函数图像实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • 利用python实现蝴蝶曲线

    利用python实现蝴蝶曲线

    这篇文章主要介绍了如何利用python实现蝴蝶曲线,自然界的很多现象都可以适当的简化用代数曲线和超越曲线来表达,下面我们就来利用去先画出小蝴蝶,需要的小伙伴可以参考一下
    2022-03-03

最新评论