Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案


Posted in Python onApril 20, 2022

通过Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案。主要原因是有些论文打印出是黑白色的,不同类别之间区分不明显,所以做了这种方案。

存在一个问题:不知道如何根据填充图案设置图例,本文中可谓“曲线救国”,将图例的颜色块设置为了白色,所以如果有人知道如何根据hatching设置图例可以讨论,原始的legend方法中是未提供该类参数的。

图形如下:

Python中的matplotlib绘制百分比堆叠柱状图,并为每一个类别设置不同的填充图案

代码如下

import numpy as np
import matplotlib.pyplot as plt
import matplotlib.patches as mpatches
import matplotlib.ticker as mtick
from matplotlib.ticker import PercentFormatter

#设置填充的图案
marks = ['o','/','*','..','\\'] 
labels = [i for i in range(2010, 2021)]
#数据
first = [42.85,    41.15,39.41,35.35,35.53,30.45,29.81,31.85,32.41,30.42,31.49]
second = [23.20,26.40,27.77,29.02,32.30,35.40,36.42,35.95,35.45,34.00,31.93]
third = [14.08,12.99,12.51,11.54,11.70,12.27,12.69,11.81,10.63,9.98,9.95]
fourth = [16.14,16.17,17.34,21.53,17.66,19.36,18.40,17.83,19.15,23.09,24.10]
others = [3.73,3.28,2.98,2.57,2.81,2.53,2.67,2.57,2.36,2.51,2.54]
data = [first, second, third, fourth, others]

x = range(len(labels))

width = 0.35
# 将bottom_y元素都初始化为0
bottom_y = np.zeros(len(labels))
data = np.array(data)
# 为计算百分比做准备
sums = np.sum(data, axis=0)
j = 0
figsize = 8,6
figure, ax = plt.subplots(figsize=figsize)
plt.rcParams['font.sans-serif'] = ['SimHei']
for i in data:
    y = i / sums
    plt.bar(x, y, width, hatch=np.array(marks)[j], bottom=bottom_y, color='white', edgecolor='black')
    bottom_y = y + bottom_y
    plt.xticks(x, labels)
    #plt.yticks(range(1), ylabel)
    legend_labels = ['o legend1', '/ legend2', '* legend3', '· legend4',r'\ legend5']  
    color = ['white', 'white', 'white', 'white', 'white']
   
    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))

    ax.legend(handles=patches,ncol=1, bbox_to_anchor=(1, 1), borderaxespad = 0.)  # 生成legend
    figure.subplots_adjust(right=0.7)
    j+=1
#绘制平行于x轴的虚线
for i in range(1, 11, 1):
    plt.axhline(y=i/10, linestyle='dashed', color='black', linewidth=0.5)
labels = ax.get_xticklabels() + ax.get_yticklabels()
#设置数字label字体
[label.set_fontname('Times New Roman') for label in labels]
plt.savefig(r'filename.svg', format='svg')
plt.show()

以上就是本文的全部内容,希望对大家的学习有所帮助。

Python 相关文章推荐
python和bash统计CPU利用率的方法
Jul 10 Python
python 添加用户设置密码并发邮件给root用户
Jul 25 Python
Python用list或dict字段模式读取文件的方法
Jan 10 Python
解决Django模板无法使用perms变量问题的方法
Sep 10 Python
python中logging库的使用总结
Oct 18 Python
Python列表推导式、字典推导式与集合推导式用法实例分析
Feb 07 Python
python3+PyQt5实现自定义窗口部件Counters
Apr 20 Python
Python实现合并同一个文件夹下所有txt文件的方法示例
Apr 26 Python
使用Template格式化Python字符串的方法
Jan 22 Python
python接口自动化测试之接口数据依赖的实现方法
Apr 26 Python
Python使用get_text()方法从大段html中提取文本的实例
Aug 27 Python
Python GUI编程学习笔记之tkinter控件的介绍及基本使用方法详解
Mar 30 Python
Pandas 数据编码的十种方法
Apr 20 #Python
Python读取和写入Excel数据
Python 的演示平台支持 WSGI 接口的应用
Apr 20 #Python
python​格式化字符串
Apr 20 #Python
Python编写冷笑话生成器
Apr 20 #Python
Python Django / Flask如何使用Elasticsearch
Apr 19 #Python
python中mongodb包操作数据库
Apr 19 #Python
You might like
php中iconv函数使用方法
2008/05/24 PHP
PHP strtr() 函数使用说明
2008/11/21 PHP
PHP 批量更新网页内容实现代码
2010/01/05 PHP
基于php下载文件的详解
2013/06/02 PHP
php通过前序遍历树实现无需递归的无限极分类
2015/07/10 PHP
关于PHP5.6+版本“No input file specified”问题的解决
2019/12/11 PHP
身份证号码前六位所代表的省,市,区, 以及地区编码下载
2007/04/12 Javascript
动态样式类封装JS代码
2009/09/02 Javascript
JavaScript开发规范要求(规范化代码)
2010/08/16 Javascript
jQuery前台数据获取实现代码
2011/03/16 Javascript
jQuery自动切换/点击切换选项卡效果的小例子
2013/08/12 Javascript
如何设置iframe高度自适应在跨域情况下的可用方法
2013/09/06 Javascript
使用CSS3的scale实现网页整体缩放
2014/03/18 Javascript
详解原生JavaScript实现jQuery中AJAX处理的方法
2016/05/10 Javascript
12306 刷票脚本及稳固刷票脚本(防挂)
2017/01/04 Javascript
实例教学如何写vue插件
2017/11/30 Javascript
微信小程序使用npm支持踩坑
2018/11/07 Javascript
JavaScript ES6常用基础知识总结
2019/02/09 Javascript
JavaScript使用prototype属性实现继承操作示例
2020/05/22 Javascript
React实现todolist功能
2020/12/28 Javascript
[51:11]2014 DOTA2国际邀请赛中国区预选赛5.21 LGD-CDEC VS DT
2014/05/22 DOTA
python实现的jpg格式图片修复代码
2015/04/21 Python
Python环境下安装使用异步任务队列包Celery的基础教程
2016/05/07 Python
python使用psutil模块获取系统状态
2016/08/27 Python
python django事务transaction源码分析详解
2017/03/17 Python
Python常用算法学习基础教程
2017/04/13 Python
Django中自定义admin Xadmin的实现代码
2019/08/09 Python
Python中正反斜杠(‘/’和‘\’)的意义与用法
2019/08/12 Python
在python中利用try..except来代替if..else的用法
2019/12/19 Python
PyTorch-GPU加速实例
2020/06/23 Python
Pycharm如何自动生成头文件注释
2020/11/14 Python
村官学习十八大感想
2014/01/15 职场文书
学校运动会广播稿
2014/10/11 职场文书
党的群众路线教育实践活动心得体会(教师)
2014/10/31 职场文书
房屋产权证明书
2015/06/19 职场文书
一文了解JavaScript用Element Traversal新属性遍历子元素
2021/11/27 Javascript