python数据可视化 - matplotlib专题:带数据标签的双batch的Bar图绘制示例

简介: python数据可视化 - matplotlib专题:带数据标签的双batch的Bar图绘制示例

基于matplotlib的双Batch带标签bar图生成函数


【代码实现】

import matplotlib
import matplotlib.pyplot as plt
import numpy as np
def barchart_ax_2Batch(title,
                    xlabel,ylabel,
                    batch1_name,batch2_name,
                    x_text,batch1,batch2,
                    background_color,Batch1_color,Batch2_color):
    plt.rcParams['font.sans-serif'] = ['KaiTi']           # 指定默认字体以解决中文乱码
    x = np.arange(len(x_text))
    width = 0.35
    fig, ax = plt.subplots()
    rects1 = ax.bar(x - width/2, batch1, width, label = batch1_name, color = Batch1_color)   
                                            #- width/2右移一半宽度
    rects2 = ax.bar(x + width/2, batch2, width, label = batch2_name, color = Batch2_color)   
                                            #+ width/2左移一半宽度 否则两图会重合
    ax.patch.set_facecolor(background_color)     #设置背景色
     # 设置各种标签名称的数据来源
    ax.set_title(title)              #添加标题
    ax.set_xlabel(xlabel)           #添加横轴标题(标签)
    ax.set_ylabel(ylabel)           #添加纵轴标题(标签)
    ax.set_xticks(x)               #以列表x中的内容为所作图横轴刻度
    ax.set_xticklabels(x_text)       #添加横轴数据/文本
    ax.legend()                  #添加图例
    #为Batch1添加数据标签
    for rect in rects1:
        height = rect.get_height()
        ax.annotate('{}'.format(height),      
            xy=(rect.get_x() + rect.get_width() / 2, height),
            xytext=(0,3),                                # 3 points vertical offset
            textcoords="offset points",
            ha='center', va='bottom')
    #为Batch2添加数据标签
    for rect in rects2:
        height = rect.get_height()
        ax.annotate('{}'.format(height),      
            xy=(rect.get_x() + rect.get_width() / 2, height),
            xytext=(0,3), 
            textcoords="offset points",
            ha='center', va='bottom')
            plt.grid(linestyle = "dotted",color = "r")    #添加网格线
    fig.tight_layout()
    plt.show()

【调用实例】

新手调用时,请尽量按照两部走的原则:

  • 1.先定义各种待传入函数接口的数据,
  • 2.调用函数。
    参数很多时不要把所有参数的取值都写到调用函数处,这样将降低可读性。
#定义各种名称
title = '期末平均考成绩比较图'
xlabel = '科目'
ylabel = '得分'
batch1_name = '高2020-07班'
batch2_name = '高2020-09班'
#定义数据值
x_text = ['语文', '数学', '英语', '物理', '化学' ,'生物']
batch1 = [87, 118, 101, 106, 76, 71]
batch2 = [112, 97, 116, 99, 89, 83]
#定义颜色
background_color = "lightskyblue"
Batch1_color = "red"
Batch2_color = "blue"
#最后调用函数以绘图
barchart_ax_2Batch(title,
                 xlabel,ylabel,
                 batch1_name,batch2_name,
                 x_text,batch1,batch2,
                 background_color,Batch1_color,Batch2_color)

生成图片效果如下:

内容仅供参考,如需使用请指明出处。



202012.29.更新/回复

【事项记录】:有同学留言,说想要绘制百分比标签的。其实这不难。可以如下思路操作:

  • 1.输入数据前先表列表中的数据标准化,即处理成百分数的一百倍。比如百分之97.15%则处理成97.15
  • 2.对函数中格式化操作稍微更改。
    还是用上面的数据举个栗子吧,假设我们想得到两个班同学各科成绩占满分的占比。
import matplotlib
import matplotlib.pyplot as plt
import seaborn as sns
def bar_2batch( x_labels,y1,y2,
                       title=None,xtitle=None,ytitle=None,
                       legend1=None,legend2=None,
                       background_color="#ffffff",Batch1_color="#5B9BD5",Batch2_color="#ED7D31"):
   plt.rcParams['font.sans-serif'] = ['KaiTi']
   pylab.rcParams['figure.figsize'] = (7.0, 4.0)
   x = np.arange(len(x_labels))
   width = 0.25
   fig, ax = plt.subplots()
   rects1 = ax.bar(x - width/2, y1, width, label = legend1, color = Batch1_color)   
   rects2 = ax.bar(x + width/2, y2, width, label = legend2, color = Batch2_color)   
   ax.patch.set_facecolor(background_color)
   ax.set_title(title)
   ax.set_xlabel(xtitle)
   ax.set_ylabel(ytitle) 
   ax.set_xticks(x) 
   ax.set_xticklabels(x_labels)
   if (legend1 is not None) or (legend1 is not None):  
       ax.legend()
   def add_dlb(rects):
       for rect in rects:
           height = rect.get_height()
           ax.annotate('{0:.2f}%'.format(height), xy=(rect.get_x() + rect.get_width() / 2, height),xytext=(0,3), textcoords="offset >points", ha='center', va='bottom')
   add_dlb(rects1)
   add_dlb(rects2)
   plt.grid(linestyle = "-",color = "#DBDBDB") 
   fig.tight_layout()
   plt.show()
# 定义各种名称
title = '两班学生各科目成绩满分比'
xtitle = '科目'
ytitle = '得分'
legend1 = '高2020-07班'
legend2 = '高2020-09班'
# 定义数据值
x_labels = ['语文', '数学', '英语', '物理', '化学' ,'生物']
y1 = [87/150*100, 118/150*100, 101/150*100, 96/100*100, 76/100*100, 71/100*100]
y2 = [112/150*100, 97/150*100, 116/150*100, 99/100*100, 89/100*100, 83/100*100]
# 最后调用函数以绘图
bar_2batch(x_labels,y1,y2,title=title,legend1=legend1,legend2=legend2)

效果如图所示:

由于定义了默认参数,当不需要要标题等参数的时候,你甚至也可以只给出数据。比如:

bar_2batch(x_labels,y1,y2)

其运行结果为:


20201230 更新日志

顺便补充一点,如果绘制单Batch的,又想使用seaborn主题,还想在jupyter中改变尺寸大小,好。那么一下这个内容适合你。当然多Batch只要将之前的代码同理稍作修改就好了。


直接给出代码吧:

import matplotlib
import matplotlib.pyplot as plt
import numpy as np
import pylab
import seaborn as sns
sns.set(style="darkgrid")
def bar_1batch( x_labels,y1,title=None,xtitle=None,ytitle=None,legend1=None,Batch1_color="#5B9BD5"):
    plt.rcParams['font.sans-serif'] = ['KaiTi']           # 指定默认字体以解决中文乱码
    x = np.arange(len(x_labels))
    width = 0.75
    fig, ax = plt.subplots()
    rects1 = ax.bar(x - width/2, y1, width, label = legend1, color = Batch1_color)
    if legend1 != None:
        ax.legend()                        #添加图例
    ax.set_title(title)               #添加标题
    ax.set_xlabel(xtitle)             #添加横轴标题(标签)
    ax.set_ylabel(ytitle)             #添加纵轴标题(标签)
    ax.set_xticks(x)                   #以列表x中的内容为所作图横轴刻度
    ax.set_xticklabels(x_labels)       #添加横轴数据/文本
    pylab.rcParams['figure.figsize'] = (16.0, 5.0)
    plt.rcParams['font.sans-serif'] = ['KaiTi']
    matplotlib.rcParams['axes.unicode_minus'] = False
    def add_dlb(rects):
        for rect in rects:
            height = rect.get_height()
            ax.annotate('{}'.format(height), xy=(rect.get_x() + rect.get_width() / 2, height),xytext=(0,3), textcoords="offset points", ha='center', va='bottom')
    add_dlb(rects1)
    plt.grid(linestyle = "-",color = "#DBDBDB")
    fig.tight_layout()
    plt.show()
# 定义数据
n=36
x_labels = [str(i) for i in range(n)]
y1 = np.random.randint(10,90,size=(1,n),dtype=int)[0]
#最后调用写好的函数绘图
bar_1batch(x_labels,y1)

在jupyter中运行结果如下图所示:

这样就控制图像的大小让我们看起来更“爽”。

目录
相关文章
|
1月前
|
数据挖掘 Python
Python示例,展示如何找到最近一次死叉之后尚未形成金叉的位置
【10月更文挑战第7天】金融分析中,“死叉”指短期移动平均线(如MA5)跌破长期移动平均线(如MA10),而“金叉”则相反。本文提供Python代码示例,用于找出最近一次死叉后未形成金叉的位置,涵盖移动平均线计算、交叉点判断及结果输出等步骤,适合金融数据分析。
35 4
|
3天前
|
移动开发 数据可视化 数据挖掘
利用Python实现数据可视化:以Matplotlib和Seaborn为例
【10月更文挑战第37天】本文旨在引导读者理解并掌握使用Python进行数据可视化的基本方法。通过深入浅出的介绍,我们将探索如何使用两个流行的库——Matplotlib和Seaborn,来创建引人入胜的图表。文章将通过具体示例展示如何从简单的图表开始,逐步过渡到更复杂的可视化技术,帮助初学者构建起强大的数据呈现能力。
|
10天前
|
数据可视化 JavaScript 前端开发
Python中交互式Matplotlib图表
【10月更文挑战第20天】Matplotlib 是 Python 中最常用的绘图库之一,但默认生成的图表是静态的。通过结合 mpld3 库,可以轻松创建交互式图表,提升数据可视化效果。本文介绍了如何使用 mpld3 在 Python 中创建交互式散点图、折线图和直方图,并提供了详细的代码示例和安装方法。通过添加插件,可以实现缩放、平移和鼠标悬停显示数据标签等交互功能。希望本文能帮助读者掌握这一强大工具。
32 5
|
15天前
|
数据采集 数据可视化 数据处理
如何使用Python实现一个交易策略。主要步骤包括:导入所需库(如`pandas`、`numpy`、`matplotlib`)
本文介绍了如何使用Python实现一个交易策略。主要步骤包括:导入所需库(如`pandas`、`numpy`、`matplotlib`),加载历史数据,计算均线和其他技术指标,实现交易逻辑,记录和可视化交易结果。示例代码展示了如何根据均线交叉和价格条件进行开仓、止损和止盈操作。实际应用时需注意数据质量、交易成本和风险管理。
35 5
|
13天前
|
数据挖掘 Python
Python示例,展示如何找到最近一次死叉之后尚未形成金叉的位置
金融分析中,“死叉”指短期移动平均线(如MA5)跌破长期移动平均线(如MA10),而“金叉”则相反。本文提供Python代码示例,用于找出最近一次死叉后未形成金叉的位置,涵盖移动平均线计算、交叉点判断及结果输出等步骤,适合金融数据分析。
19 1
|
28天前
|
数据可视化 定位技术 Python
Python数据可视化--Matplotlib--入门
Python数据可视化--Matplotlib--入门
22 0
|
28天前
|
Linux Android开发 开发者
【Python】GUI:Kivy库环境安装与示例
这篇文章介绍了 Kivy 库的安装与使用示例。Kivy 是一个开源的 Python 库,支持多平台开发,适用于多点触控应用。文章详细说明了 Kivy 的主要特点、环境安装方法,并提供了两个示例:一个简单的 Hello World 应用和一个 BMI 计算器界面。
42 0
|
1月前
|
PyTorch 测试技术 算法框架/工具
Python中Thop库的常见用法和代码示例
肆十二在B站分享了关于THOP(Torch-OpCounter)的实战教学视频。THOP是一个用于计算PyTorch模型操作数和计算量的工具,帮助开发者评估模型复杂度和性能。本文介绍了THOP的安装、使用方法及基本用例,包括如何计算模型的FLOPs和参数量。
72 0
|
1月前
|
Python
Python中tqdm模块的常用方法和示例
`tqdm` 是一个快速、可扩展的Python进度条库,适用于长循环中添加进度提示。通过封装迭代器 `tqdm(iterator)`,可以轻松实现进度显示。支持自定义描述、宽度及嵌套进度条,适用于多种迭代对象。在Jupyter notebook中,可自动调整显示效果。
32 0
|
1月前
|
Python
Python中threading模块的常用方法和示例
Python 的 `threading` 模块提供了多线程编程的能力,允许同时执行多个线程。主要类包括 `Thread`、`Lock` 和 `Condition`。`Thread` 类用于创建和管理线程,`Lock` 用于同步线程,防止资源竞争,`Condition` 用于线程间协调。本文介绍了这些类的常用方法及示例代码,帮助你更好地理解和使用多线程编程。
25 0