【论文复刻】 堆叠柱状图变形

复刻了一下这篇论文里的fig4a:Impacts of COVID-19 and fiscal stimuli on global emissions and the Paris Agreement | Nature Climate Change

效果图:

主要步骤:

1. 数据准备:随机赋值

2. 数据处理:计算了一个百分数

3. 图像绘制:(1)绘制变形的堆叠柱状图

                      (2)灵活控制文本位置

                      (3)用箭头突出显示变化

详细代码:着急的直接拖到最后有完整代码

步骤一:导入库包及图片存储路径并设置中文字体为宋体,西文为新罗马(没有的库包要先下好奥)

# 导入库及文件
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import rcParams
# 设置西文字体为新罗马字体,中文宋体
config = {"font.family": 'serif',"font.size": 12,"mathtext.fontset": 'stix',"font.serif": ['SimSun'],}
rcParams.update(config)
rcParams['axes.unicode_minus']=False
###############################################################################

步骤二:前期准备数据

figpath = r'H:/00.csdn/02fig/'# 随机赋值数据
a0 = 140.9
a = np.array([0.3, 0.5, 0.6, 0.4, 0.2])x = range(1, 10, 1)# 计算百分比并进行格式化
proportion1 = a/np.sum(a)*100
proportion1 =['{:.2f}%'.format(i) for i in proportion1]# 文本标签
proportion2 = ['aaaaaaaaaaaa','bbbbbbbbbbbb','cccccccccccc','dddddddddddd','eeeeeeeeeeee','ffffffffffff','gggggggggggg']colors = ['#656565', '#D27D75', '#81BAC8', '#64A99C', '#64A99C', '#A49384']

步骤三:绘制柱状图及其上下文本

###############################################################################
width = 0.8fig = plt.figure(figsize=(8, 8))
ax = fig.add_axes([0.1, 0.25, 0.6, 0.4])# 绘制第一个bar
ax.bar(x[0], a0, width, align='center',  color=colors[0], bottom=0)
ax.text(x[0], 140.1 , 'xxxxxxx', color='w', fontsize=10, rotation=90, horizontalalignment="center")# 绘制第二到五个bar
sum0 = a0
for i in range(0, 5, 1):ax.bar(x[i+1], a[i], width, align='center',  color=colors[i+1], bottom=sum0)sum0 += a[i]if i < 2: ax.text(x[i+1], sum0-a[i]-0.2 , proportion1[i], fontsize=10, rotation=0, horizontalalignment="center")ax.text(x[i+1], sum0+0.1 , proportion2[i], fontsize=10, rotation=90, horizontalalignment="center")elif i >= 2 and i < 5:ax.text(x[i+1], sum0+0.1, proportion1[i], fontsize=10, rotation=0, horizontalalignment="center")ax.text(x[i+1], sum0-a[i]-1.0 , proportion2[i], fontsize=10, rotation=90, horizontalalignment="center")# 添加6 7 文本
ax.text(x[6], sum0-0.5, proportion2[5], fontsize=10, rotation=90, horizontalalignment="center")
ax.text(x[7], sum0-0.5, proportion2[6], fontsize=10, rotation=90, horizontalalignment="center")# 绘制第八个bar
ax.bar(x[8], sum0, width, align='center',  color=colors[0], bottom=0)
ax.text(x[8], 140.1 , 'xxxxxxxxxxxxxxx', color='w', fontsize=10, rotation=90, horizontalalignment="center")

步骤四:设置标题文本,坐标轴信息,及箭头

# 添加标题信息
ax.text(5, 143.5 , 'xxxxxxxxxxx\nyyyyyyyyyyyyyy', color='k', fontsize=10, rotation=0, horizontalalignment="center")# 设置坐标轴信息
ax.set(xlim=(0, 10), xticks=[],ylim=(140, 144), yticks=range(140, 145, 1), yticklabels=range(140, 145, 1), ylabel = 'y轴')# 添加箭头及箭头上方文本
plt.arrow(2,140.2, 6, 0, width=0.01, head_width=0.06, facecolor='gray', edgecolor='gray')
ax.text(5, 140.3 , '+ '+'%3.2f' %((sum0-a0)/a0) + '%', color='k', fontsize=10, rotation=0, horizontalalignment="center")

步骤五:保存图像

###############################################################################
# 保存图像
plt.savefig(figpath+'305 COVID-19 Fig4', dpi=600, bbox_inches = 'tight')
plt.show()

完整代码在这里:

# 导入库及文件
import numpy as np
import matplotlib.pyplot as plt
from matplotlib import rcParams
# 设置西文字体为新罗马字体,中文宋体
config = {"font.family": 'serif',"font.size": 12,"mathtext.fontset": 'stix',"font.serif": ['SimSun'],}
rcParams.update(config)
rcParams['axes.unicode_minus']=False
###############################################################################
figpath = r'H:/00.csdn/02fig/'# 随机赋值数据
a0 = 140.9
a = np.array([0.3, 0.5, 0.6, 0.4, 0.2])x = range(1, 10, 1)# 计算百分比并进行格式化
proportion1 = a/np.sum(a)*100
proportion1 =['{:.2f}%'.format(i) for i in proportion1]# 文本标签
proportion2 = ['aaaaaaaaaaaa','bbbbbbbbbbbb','cccccccccccc','dddddddddddd','eeeeeeeeeeee','ffffffffffff','gggggggggggg']colors = ['#656565', '#D27D75', '#81BAC8', '#64A99C', '#64A99C', '#A49384']
###############################################################################
width = 0.8fig = plt.figure(figsize=(8, 8))
ax = fig.add_axes([0.1, 0.25, 0.6, 0.4])# 绘制第一个bar
ax.bar(x[0], a0, width, align='center',  color=colors[0], bottom=0)
ax.text(x[0], 140.1 , 'xxxxxxx', color='w', fontsize=10, rotation=90, horizontalalignment="center")# 绘制第二到五个bar
sum0 = a0
for i in range(0, 5, 1):ax.bar(x[i+1], a[i], width, align='center',  color=colors[i+1], bottom=sum0)sum0 += a[i]if i < 2: ax.text(x[i+1], sum0-a[i]-0.2 , proportion1[i], fontsize=10, rotation=0, horizontalalignment="center")ax.text(x[i+1], sum0+0.1 , proportion2[i], fontsize=10, rotation=90, horizontalalignment="center")elif i >= 2 and i < 5:ax.text(x[i+1], sum0+0.1, proportion1[i], fontsize=10, rotation=0, horizontalalignment="center")ax.text(x[i+1], sum0-a[i]-1.0 , proportion2[i], fontsize=10, rotation=90, horizontalalignment="center")# 添加6 7 文本
ax.text(x[6], sum0-0.5, proportion2[5], fontsize=10, rotation=90, horizontalalignment="center")
ax.text(x[7], sum0-0.5, proportion2[6], fontsize=10, rotation=90, horizontalalignment="center")# 绘制第八个bar
ax.bar(x[8], sum0, width, align='center',  color=colors[0], bottom=0)
ax.text(x[8], 140.1 , 'xxxxxxxxxxxxxxx', color='w', fontsize=10, rotation=90, horizontalalignment="center")# 添加标题信息
ax.text(5, 143.5 , 'xxxxxxxxxxx\nyyyyyyyyyyyyyy', color='k', fontsize=10, rotation=0, horizontalalignment="center")# 设置坐标轴信息
ax.set(xlim=(0, 10), xticks=[],ylim=(140, 144), yticks=range(140, 145, 1), yticklabels=range(140, 145, 1), ylabel = 'y轴')# 添加箭头及箭头上方文本
plt.arrow(2,140.2, 6, 0, width=0.01, head_width=0.06, facecolor='gray', edgecolor='gray')
ax.text(5, 140.3 , '+ '+'%3.2f' %((sum0-a0)/a0) + '%', color='k', fontsize=10, rotation=0, horizontalalignment="center")
###############################################################################
# 保存图像
plt.savefig(figpath+'305 COVID-19 Fig4', dpi=600, bbox_inches = 'tight')
plt.show()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/12536.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器学习中常用的几种距离——欧式、余弦等

目录 一、欧式距离&#xff08;L2距离&#xff09;二、曼哈顿距离&#xff08;L1距离&#xff09;三、汉明距离四、余弦相似度 一、欧式距离&#xff08;L2距离&#xff09; &#xff08;1&#xff09;二维空间的距离公式&#xff08;三维空间的在这个基础上类推&#xff09;&…

linux内核debug(二)在线调试内核kdb/kgdb工具使用及环境搭建

目录 一、引言 二、kgdb调试 ------>2.1、kgdb板端配置 ------------>2.1.1、添加编译内核参数 ------------>2.1.2、配置 ------>2.2、kgdb本地调试环境搭建 ------------>2.2.1、串口工具 ------------>2.2.2、连接板端 ------>2.3、kgdb调试 …

31、Flink 的 DataStream API 数据流算子详解

1.算子 可以通过算子将一个或多个 DataStream 转换成新的 DataStream&#xff0c;也可以将多个数据转换算子合并成一个复杂的数据流拓扑。 2.数据流转换 a&#xff09;Map DataStream → DataStream 输入一个元素&#xff0c;转换后输出一个元素&#xff0c;示例将输入流中…

LeetCode hot100-40-N

543. 二叉树的直径 给你一棵二叉树的根节点&#xff0c;返回该树的 直径 。二叉树的 直径 是指树中任意两个节点之间最长路径的 长度 。这条路径可能经过也可能不经过根节点 root 。两节点之间路径的 长度 由它们之间边数表示。这题尝试做了一下&#xff0c;有几个测试案例通不…

4.StableDiffusion各项参数解读

经过前期的努力&#xff0c;我想大家都已经生成了自己的第一张AI作品&#xff0c;但是充满了随机性&#xff0c;每次都是不一样的&#xff0c;并且有时候生成的图片效果还不是很让人满意&#xff0c;暂且先不要着急&#xff0c;先跟着本篇文章&#xff0c;学习一些每个选项和参…

Google Chrome GPU渲染抓包

非安全模式启动 "C:\Program Files\Google\Chrome\Application\chrome.exe" --ignore-certificate-errors --allow-running-insecure-content --disable-web-security 配置环境 set RENDERDOC_HOOK_EGL0 "C:/Program Files/Google/Chrome/Application/chrom…

Windows本地部署直播录屏利器Bililive-go并实现远程添加直播间录屏

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” 文章目录 1. Bililive-go与套件下载1.1 获取ffmpeg1.2 获取Bililive-go1.3 配置套件 2. 本地运行测试3. 录屏…

【OpenCV 基础知识 2】灰度化图片

文章目录 cvCreateImagecvCvtColor完整示例代码 cvCreateImage 使用OpenCV库在Delphi中创建一个灰度图像。让我解释一下&#xff1a; gray_image : cvCreateImage(cvGetSize(image), IPL_DEPTH_8U, 1);cvGetSize(image): 这个函数返回给定图像&#xff08;在这里是image&…

【MySQL】事务及其隔离性/隔离级别

目录 一、事务的概念 1、事务的四种特性 2、事务的作用 3、存储引擎对事务的支持 4、事务的提交方式 二、事务的启动、回滚与提交 1、准备工作&#xff1a;调整MySQL的默认隔离级别为最低/创建测试表 2、事务的启动、回滚与提交 3、启动事务后未commit&#xff0c;但是…

MVP产品设计与数据指标

MVP&#xff08;minimum viable product&#xff0c;最小化可行产品&#xff09;概念最早由埃里克莱斯提出&#xff0c;刊载于哈弗商业评论&#xff0c;并有出版物《精益创业》 和常规产品不同&#xff0c;MVP更侧重于对未知市场的勘测&#xff0c;用最小的代价接触客户的方法…

学习Nginx(一):基础

介绍 Nginx是一个高性能的HTTP和反向代理的web服务器&#xff0c;它的设计重点是高并发、高性能和低内存消耗。它常被用于提供静态内容、负载均衡和作为Web服务器。 Nginx具有以下功能和特点&#xff1a; 静态文件服务&#xff1a;作为一个Web服务器&#xff0c;Nginx可以处…

GPT-4o可以用了

方法&#xff1a;挂日本/新加坡的梯子就可以了&#xff0c;打开就会弹出以下的弹窗。不过不知道可以用多久呢&#xff1f; 2024/5/15

木里风景文化|基于SSM+vue的木里风景文化管理平台的设计与实现(源码+数据库+文档)

木里风景文化管理平台 目录 基于SSM&#xff0b;vue的木里风景文化管理平台的设计与实现 一、前言 二、系统设计 三、系统功能设计 1 系统功能模块 2 管理员功能模块 3 用户功能模块 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源…

精通Linux中的编辑器(非常详细!!!)

今天我们来说一下编辑器…… Linux中的编辑器 vi&#xff1a;是一个文本编辑器&#xff0c;用于撰写文档&#xff0c;或者开发程序。 vim&#xff1a;是vi的增强版功能一致&#xff0c;可视化效果更好一些。去鼠标化编辑更加方便可定制化 注意&#xff1a;vim编辑器是一个模式…

信息系统项目管理师——十大管理过程输入、工具和技术、输出(论文篇)一

一、项目整合管理 制定项目章程 在项目管理中&#xff0c;制定项目章程是一个关键的初始过程&#xff0c;它正式授权项目的开始并为项目设定高层次的方向。项目章程的编制涉及特定的输入、采用的工具和技术&#xff0c;以及产生的输出。以下是这些方面的详细说明&#xff1a;…

如何避免父组件重新渲染,子组件也跟着渲染

当父组件重新渲染时&#xff0c;通常情况下&#xff0c;子组件也会跟着重新渲染。但是&#xff0c;有一些方法可以避免这种情况发生&#xff0c;让子组件在父组件重新渲染时不进行渲染。以下是五种常见的方法&#xff1a; 使用 React.memo 或 PureComponent&#xff1a; 使用 …

前端 JS 经典:为什么需要模块化

首先&#xff0c;自我评定一下&#xff0c;一个 js 文件&#xff0c;各位兄弟&#xff0c;最多能掌控多少行&#xff0c;什么意思呢&#xff0c;就是说&#xff0c;一个 js 文件在多少行之内&#xff0c;你是可以清楚的知道这个 JS 实现了哪些业务逻辑&#xff0c;并对这些业务…

专项资金!2024年自贡市高新技术企业奖励政策及申报各类补贴政策汇总

第一章 总 则 第一条 为积极应对经济发展新常态&#xff0c;加快培育工业发展新动力&#xff0c;持续推动产业结构优化升级&#xff0c;实现工业经济平稳较快增长&#xff0c;结合我县实际&#xff0c;制定本扶持激励办法。 第二条 人民政府将继续建立工业企业发展引导专项…

全知人工智能的黎明:OpenAI 革命性的 GPT-4o 揭晓

全知人工智能的黎明&#xff1a;OpenAI 革命性的 GPT-4o 揭晓 在一项突破性的公告中&#xff0c;OpenAI 推出了其最新的旗舰人工智能模型 GPT-4o&#xff0c;该模型有望彻底改变我们与人工智能交互的方式。这种无所不知的人工智能模型拥有前所未有的能力&#xff0c;从实时翻译…

Redis-持久化操作-AOF

持久化操作-AOF AOF是什么&#xff1f; 以日志的形式来记录每个写操作&#xff0c;将Redis执行过的所有写指令记录下来&#xff08;读操作不记录&#xff09;&#xff0c;只允许加文 件但不可以改写文件&#xff0c;redis启动之初会读取该文件重新构建数据&#xff0c;换言之…