news 2026/5/14 17:46:59

利用气泡图探索二氧化碳排放与气候变化脆弱性的关系

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
利用气泡图探索二氧化碳排放与气候变化脆弱性的关系

利用气泡图探索二氧化碳排放与气候变化脆弱性的关系

importmatplotlib.pyplotaspltimportpandasaspd

数据探索

以下数据如果有需要的同学可关注公众号HsuHeinrich,回复【数据可视化】自动获取~

url="https://raw.githubusercontent.com/holtzy/the-python-graph-gallery/master/static/data/data-CO2.csv"df=pd.read_csv(url)df.head()

Name:国家地区

:x轴位置

:y轴位置

CO2 per Capita:人均二氧化碳排放量

Color:颜色

绘制基本气泡图

# 初始化fig,ax=plt.subplots(figsize=(6,6))# 绘制散点图ax.scatter(df[' '],# x位置df[' .1'],# y位置s=df['CO2 per Capita']*10,# 气泡大小)# 标题ax.set_title('The countries with the highest vulnerability to climate change\nhave the lowest CO2 emissions',weight='bold')ax.set_xlabel('Vulnerability')ax.set_ylabel('Readiness')plt.show()

自定义颜色和布局

# 初始化fig,ax=plt.subplots(figsize=(6,6))# 绘制散点图ax.scatter(df[' '],# x位置df[' .1'],# y位置s=df['CO2 per Capita']*10,# 气泡大小c=df['Color'],# 颜色)# 标题ax.set_title('The countries with the highest vulnerability to climate change\nhave the lowest CO2 emissions',weight='bold')ax.set_xlabel('Vulnerability')ax.set_ylabel('Readiness',rotation=0,# 水平方向)# 移除边框和轴ax.spines['top'].set_visible(False)ax.spines['right'].set_visible(False)ax.spines['bottom'].set_visible(False)ax.spines['left'].set_visible(False)ax.set_xticklabels([])ax.set_yticklabels([])ax.tick_params(axis='both',which='both',length=0)plt.show()

更新标记并添加参考线

# 初始化fig,ax=plt.subplots(figsize=(6,6))# 绘制散点图ax.scatter(df[' '],# x位置df[' .1'],# y位置s=df['CO2 per Capita']*10,# 气泡大小c=df['Color'],# 颜色marker='s')# 标题ax.set_title('The countries with the highest vulnerability to climate change\nhave the lowest CO2 emissions',weight='bold')# 添加参考线ax.axvline(0.43,color='gray',linestyle='--',linewidth=0.7,alpha=0.4)ax.axhline(0.41,color='gray',linestyle='--',linewidth=0.7,alpha=0.4)# 移除边框和轴ax.spines['top'].set_visible(False)ax.spines['right'].set_visible(False)ax.spines['bottom'].set_visible(False)ax.spines['left'].set_visible(False)ax.set_xticklabels([])ax.set_yticklabels([])ax.tick_params(axis='both',which='both',length=0)plt.show()

突出注释部分国家地区

defcircle_countries(country_names:list):''' 输出包含该国家地区的边框 '''# 将边缘颜色参数初始化为默认值:与字体颜色相同df['EdgeColor']=df['Color']# 更改指定国家的边缘颜色df.loc[df['Name'].isin(country_names),'EdgeColor']='black'returndf['EdgeColor']defadd_country_name(country_names:list):''' 在标记顶部添加国家地区名称 '''# 迭代每个国家地区forcountry_nameincountry_names:# 查找国家地区在轴上的位置x_axis=df.loc[df['Name']==country_name,' ']y_axis=df.loc[df['Name']==country_name,' .1']# 预防报警,采取警告中建议的方式处理x_axis_value=float(x_axis.iloc[0])y_axis_value=float(y_axis.iloc[0])# 将文本添加到正确的位置,稍微移动到顶部以方便阅读ax.text(x_axis_value,y_axis_value+0.025,# 位置country_name,# 标签size=6,# 文本大小ha='center',# 居中对齐)
# 初始化fig,ax=plt.subplots(figsize=(6,6))# 需要突出的国家地区列表country_to_circle=['Norway','Singapore','U.S.','Czech Republic','Qatar','Bahrain','Somalia','Sudan','India','Trinidad and Tobago','Chad']# Define the edgecolors according to the listedgecolors=circle_countries(country_to_circle)# 绘制散点图ax.scatter(df[' '],# x位置df[' .1'],# y位置s=df['CO2 per Capita']*10,# 气泡大小c=df['Color'],# 颜色edgecolor=edgecolors,linewidths=0.6,marker='s',zorder=2)# 添加国家地区名称add_country_name(country_to_circle)# 标题title='The countries with the highest vulnerability to climate change\nhave the lowest CO2 emissions'fig.text(0,0.97,# 相对位置title,fontsize=11,ha='left',family='dejavu sans',weight='bold')# 子标题subtitle='All countries sorted by their vulnerability and readiness to climate change. The size shows the CO2 emission\nper person in that country'fig.text(0,0.92,# 相对位置subtitle,fontsize=8,ha='left',family='dejavu sans',multialignment='left')# 添加参考线ax.axvline(0.43,color='gray',linestyle='--',linewidth=0.7,alpha=0.4)ax.axhline(0.41,color='gray',linestyle='--',linewidth=0.7,alpha=0.4)# 移除边框和轴ax.spines['top'].set_visible(False)ax.spines['right'].set_visible(False)ax.spines['bottom'].set_visible(False)ax.spines['left'].set_visible(False)ax.set_xticklabels([])ax.set_yticklabels([])ax.tick_params(axis='both',which='both',length=0)# 添加文本注释标签fig.text(0.1,0.45,'High readiness',color='silver',size=8)fig.text(0.1,0.4,'Low readiness',color='silver',size=8)# 在上述注释标签周围添加箭头arrowprops=dict(arrowstyle="->",color='silver',lw=0.4)ax.annotate("",xy=(0.25,0.32),xytext=(0.25,0.37),arrowprops=arrowprops)ax.annotate("",xy=(0.25,0.5),xytext=(0.25,0.45),arrowprops=arrowprops)plt.show()

参考:Bubble plot with specific annotations and customization

共勉~

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/12 13:49:54

为什么顶级投行都在用R做风险模拟?深度解析蒙特卡洛方法的五大优势

第一章:为什么顶级投行青睐R语言进行风险模拟在金融工程与量化分析领域,R语言已成为顶级投行进行风险模拟的首选工具。其强大的统计建模能力、丰富的金融扩展包以及灵活的数据处理机制,使其在复杂市场环境下的风险评估中表现出色。卓越的统计…

作者头像 李华
网站建设 2026/5/12 10:21:39

【DevSecOps必修课】:基于Docker Scout的5阶段漏洞修复体系构建

第一章:DevSecOps视角下的容器安全挑战在现代软件交付流程中,容器技术已成为DevOps实践的核心组件。然而,随着容器化部署的普及,安全问题不再局限于传统基础设施层面,而是贯穿于开发、构建、部署与运行的全生命周期。从…

作者头像 李华
网站建设 2026/5/7 23:59:17

【归并排序】【快速排序】

【归并排序】【快速排序】 详细讲解见以下视频链接 归并排序视频链接 快速排序视频链接 个人理解&#xff1a; 归并排序&#xff1a;先分再排 快速排序&#xff1a;先排再分 归并排序代码&#xff1a; #include <bits/stdc.h> #define int long long using namespac…

作者头像 李华
网站建设 2026/5/13 13:22:29

(混合检索性能革命):Dify响应时间从3秒到200ms的实践路径

第一章&#xff1a;混合检索的 Dify 响应时间在构建基于大语言模型的应用时&#xff0c;Dify 作为一款低代码平台&#xff0c;支持将向量检索与关键词检索融合&#xff0c;实现高效的混合检索机制。该机制显著影响系统的响应时间&#xff0c;尤其在高并发或大规模数据场景下&am…

作者头像 李华
网站建设 2026/5/13 15:50:30

视频创作SDK,覆盖从拍摄、剪辑、特效、合成等功能

在短视频、直播、社交娱乐和企业数字化内容爆发的时代&#xff0c;视频已不再是专业创作者的专属工具&#xff0c;而是每个人表达自我、传递信息的重要媒介。面对海量用户对高质量、个性化、高效率视频创作的需求&#xff0c;美摄科技凭借多年音视频技术积累与AI算法优势&#…

作者头像 李华
网站建设 2026/5/13 12:03:28

Java毕设选题推荐:基于Springboot+Vue的天气预报管理系统基于springboot天气预报查询系统天气信息【附源码、mysql、文档、调试+代码讲解+全bao等】

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华