轻松玩转Python,5个步骤打造惊艳的折线图

本文介绍了如何使用Matplotlib库创建吸引人的图表,展示了如何从公开数据集中提取过去50年各国GDP信息,重点讲解了基本图、添加关键元素、突出重点国家以及修改图表外观,以清晰展示2022年最富有的20个国家GDP变化。

1、简介

最富有的5个国家的GDP随时间的演变

Matplotlib可以快速轻松地使用现成的函数绘制图表,但是微调步骤需要花费更多精力。今天就来介绍如何使用Matplotlib绘制吸引人的图表。

本文详细介绍如何从下面这张图↓

2、数据

为了说明方法,本文使用了包含过去50年各国GDP信息的公开数据集:

来源:世界银行国民账户数据和OECD(经济合作与发展组织)国民账户数据文件。

许可证URL:https://datacatalog.worldbank.org/public-licenses#cc-by

导入必要的软件包、读取数据、绘制图表,对2022年的GDP前20个国家进行筛选:

import pandas as pd   import matplotlib.pyplot as plt   from datetime import timedelta      # 读取数据   df = pd.read_csv('88a1e584-0a94-4e73-b650-749332831ef4_Data.csv', sep=',')   df.drop(['Series Name', 'Series Code', 'Country Code'], axis=1, inplace=True)   df = df.dropna(subset=['Country Name'])      # 对 2022 年最富有的 20 个国家进行筛选   top_20_countries = df[df['Year'] == '2022-01-01'].sort_values('GDP', ascending = False).head(20)['Country Name'].tolist()   df = df[df['Country Name'].isin(top_20_countries)].reset_index(drop = True)      df.head()   

3、基本图

首先,只需四行代码就足以创建图形,并循环遍历各国以绘制它们各自的折线:

# 创建图形和坐标轴对象,指定尺寸和DPI   fig, ax = plt.subplots(figsize=(13.33,7.5), dpi = 96)      # 绘制折线   for country in top_20_countries:       data = df[df['Country Name'] == country]       line = ax.plot(data['Year'], data['GDP'], label=country)   

最基本的Matplotlib折线图

4、基本要素

接下来向图表中添加一些关键内容,使其更易于观众阅读。

  • 网格

为了提高图表的可读性,网格是必不可少的。将网格的透明度设置为0.5,这样它们就不会对数据点造成太大干扰。

  • X轴和Y轴重新格式化

为了更全面地了解微调的可能性,本文故意添加了更多的参数。例如,X轴不需要major_formattermajor_locator对象,因为本文只显示年份,但如果读者的X轴包含其他数字,这就会派上用场。

  • 图例

由于要显示很多条线,因此添加标签和图例非常重要,这样读者就能知道哪条线是哪条线。

# 添加图例   ax.legend(loc="best", fontsize=8)      # 创建网格   ax.grid(which="major", axis='x', color='#DAD8D7', alpha=0.5, zorder=1)   ax.grid(which="major", axis='y', color='#DAD8D7', alpha=0.5, zorder=1)      # 重新格式化x轴标签和刻度线标签   ax.set_xlabel('', fontsize=12, labelpad=10) # 不需要轴标签   ax.xaxis.set_label_position("bottom")   #ax.xaxis.set_major_formatter(lambda s, i : f'{s:,.0f}') #以防万一我们需要额外的格式设置   #ax.xaxis.set_major_locator(MaxNLocator(integer=True)) #以防我们需要额外的格式化   ax.xaxis.set_tick_params(pad=2, labelbottom=True, bottom=True, labelsize=12, labelrotation=0)      # 重新格式化y轴   ax.set_ylabel('GDP (Billions USD)', fontsize=12, labelpad=10)   ax.yaxis.set_label_position("left")   ax.yaxis.set_major_formatter(lambda s, i : f'{s*10**-9:,.0f}')   #ax.yaxis.set_major_locator(MaxNLocator(integer=True)) #以防我们需要额外的格式化   ax.yaxis.set_tick_params(pad=2, labeltop=False, labelbottom=True, bottom=False, labelsize=12)   

为本文的图表添加一些必要的功能

5、突出重点

接下来,突出显示最富有的五个国家,并跟踪其GDP随时间的变化。在字典中定义了特定的颜色和线条样式,并对代码稍作修改,以单独绘制它们。

# 颜色和线条样式   colors_dict = {'United States': '#014f86', 'China': '#DC0000', 'Japan': '#ff4d6d', 'Germany': '#403d39', 'India': '#6a994e'}   line_styles_dict = {'United States': '-', 'China': '-', 'Japan': '-', 'Germany': '-', 'India': '-'}      # 绘制前5条线   for country in top_20_countries[:5]:       color = colors_dict.get(country, 'grey')  # 从字典中获取颜色,如果找不到,默认为灰色       line_style = line_styles_dict.get(country, '-')  # 从字典中获取线条样式,如果未找到,默认为实线       data = df[df['Country Name'] == country]       line = ax.plot(data['Year'], data['GDP'], color=color, linestyle=line_style, zorder=2, label=country)      # 添加图例   ax.legend(loc="best", fontsize=8)      # 绘制剩余部分   for country in top_20_countries[5:]:       data = df[df['Country Name'] == country]       line = ax.plot(data['Year'], data['GDP'], color='grey', linestyle=':', linewidth=0.5, zorder=2)   

仍然是相同的折线图,但故事更清晰了

6、修改外观

为本文的图表添加一些功能,可以使其看起来更加专业。它们将位于所有图表的顶部,并且与本文中使用的数据无关。

通过下面的代码片段,这些调整将很容易实现。

读者可以根据自己的需求对其进行调整,以创建自己的视觉风格。

  • 边框

边框是图表周围可见的框。除了左边的边框会设置得稍微粗一些外,其余的边框都将被移除。

  • 顶部的红线和矩形

在标题上方添加一条红线和一个矩形,以便将图表与上方的文本很好地隔离开来。

  • 标题和副标题

添加标题来介绍图表,副标题可以用来进一步解释内容,甚至呈现初步的结论。

  • 来源

在所有制作的图表中都必不可少的一项。

  • 调整边距

调整图表区域周围的边距,以确保充分利用所有可用空间。

  • 设置白色背景

将背景设置为白色(默认为透明)在通过电子邮件、Teams或任何其他工具发送图表时非常有用,因为透明背景可能会造成问题。

# 移除边框   ax.spines[['top','right','bottom']].set_visible(False)      # 加粗左侧边框   ax.spines['left'].set_linewidth(1.1)      # 在顶部添加红线和矩形   ax.plot([0.05, .9], [.98, .98], transform=fig.transFigure, clip_on=False, color='#E3120B', linewidth=.6)   ax.add_patch(plt.Rectangle((0.05,.98), 0.04, -0.02, facecolor='#E3120B', transform=fig.transFigure, clip_on=False, linewidth = 0))      # 添加标题和副标题   ax.text(x=0.05, y=.93, s="Evolution of the 20 Richest Countries GDP over the Past 50 Years", transform=fig.transFigure, ha='left', fontsize=14, weight='bold', alpha=.8)   ax.text(x=0.05, y=.90, s="Focus on the current 5 richest countries from 1973 to 2022", transform=fig.transFigure, ha='left', fontsize=12, alpha=.8)      # 设置来源文本   ax.text(x=0.05, y=0.12, s="Source: World Bank - https://databank.worldbank.org/", transform=fig.transFigure, ha='left', fontsize=10, alpha=.7)      # 调整绘图区域周围的边距   plt.subplots_adjust(left=None, bottom=0.2, right=None, top=0.85, wspace=None, hspace=None)      # 设置白色背景   fig.patch.set_facecolor('white')   

本文的视觉风格应用于图表,使其更加整洁

7、点睛之笔

为了得到在文章开头介绍的最终结果,剩下要做的就是实现这几个额外的组件:

  • 终点标记

这些元素纯粹是为了美观,但能为本文的折线图增添一份亮点。用标记突出显示每条折线的最后一个点,使其更加醒目。

  • 注释

借助annotate方法,可以突出显示图表中的特定点,并在其上直接添加注释。

# 绘制前5条线   for country in top_20_countries[:5]:       color = colors_dict.get(country, 'grey')  # 从字典中获取颜色,如果找不到,默认为黑色       line_style = line_styles_dict.get(country, '-')  # 从字典中获取线条样式,如果找不到,默认为实线       data = df[df['Country Name'] == country]       line = ax.plot(data['Year'], data['GDP'], color=color, linestyle=line_style, zorder=2, label = country)       ax.plot(data['Year'].iloc[-1], data['GDP'].iloc[-1], 'o', color=color, markersize=10, alpha=0.3)       ax.plot(data['Year'].iloc[-1], data['GDP'].iloc[-1], 'o', color=color, markersize=5)      # 在图表上添加一些文字   ax.annotate('During the 2000s,\nChina began experiencing rapid economic growth,\noutpacing all other countries.',               (data['Year'].iloc[-18], 2000000000000),               xytext=(data['Year'].iloc[-28]-timedelta(days=500), 18000000000000),               ha='left', fontsize=9, arrowprops=dict(arrowstyle='-|>', facecolor='k', connectionstyle="arc3,rad=-0.15"))   

最终成果:这个折线图清晰易读

8、结语

本文分享了使用Matplotlib绘制折线图的知识,同时提供了实用可重复使用的代码片段。

---------------------------END---------------------------

题外话

当下这个大数据时代不掌握一门编程语言怎么跟的上时代呢?当下最火的编程语言Python前景一片光明!如果你也想跟上时代提升自己那么请看一下.

在这里插入图片描述

感兴趣的小伙伴,赠送全套Python学习资料,包含面试题、简历资料等具体看下方。


👉优快云大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

一、Python所有方向的学习路线

Python所有方向的技术点做的整理,形成各个领域的知识点汇总,它的用处就在于,你可以按照下面的知识点去找对应的学习资源,保证自己学得较为全面。

img
img

二、Python必备开发工具

工具都帮大家整理好了,安装就可直接上手!img

三、最新Python学习笔记

当我学到一定基础,有自己的理解能力的时候,会去阅读一些前辈整理的书籍或者手写的笔记资料,这些笔记详细记载了他们对一些技术点的理解,这些理解是比较独到,可以学到不一样的思路。

img

四、Python视频合集

观看全面零基础学习视频,看视频学习是最快捷也是最有效果的方式,跟着视频中老师的思路,从基础到深入,还是很容易入门的。

img

五、实战案例

纸上得来终觉浅,要学会跟着视频一起敲,要动手实操,才能将自己的所学运用到实际当中去,这时候可以搞点实战案例来学习。

img

六、面试宝典

在这里插入图片描述

在这里插入图片描述

简历模板在这里插入图片描述

👉优快云大礼包🎁:全网最全《Python学习资料》免费赠送🆓!(安全链接,放心点击)

若有侵权,请联系删除

### 如何使用Python绘制适合科研使用的高质量折线图 为了绘制适合科研使用的高质量折线图,可以利用Matplotlib库的强大功能。以下将详细介绍如何通过设置颜色、线条样式、标记以及添加注释等手段提升折线图的质量和美观度[^1]。 #### 1. 数据准备与基础绘图 首先需要导入必要的库,并准备好数据。以下是一个简单的示例代码: ```python import numpy as np import matplotlib.pyplot as plt # 数据准备 x = np.linspace(0, 10, 100) # x轴数据 y1 = np.sin(x) # 第一条曲线数据 y2 = np.cos(x) # 第二条曲线数据 ``` 然后可以绘制基础的折线图: ```python plt.figure(figsize=(8, 6)) # 设置布大小 plt.plot(x, y1, label='sin(x)') # 绘制第一条曲线 plt.plot(x, y2, label='cos(x)') # 绘制第二条曲线 plt.legend() # 添加图例 plt.show() ``` #### 2. 调整颜色与线条样式 在科研图表中,合适的颜色和线条样式能够显著提升图表的可读性。可以通过`color`参数调整颜色,通过`linestyle`参数调整线条样式。例如: ```python plt.figure(figsize=(8, 6)) plt.plot(x, y1, color='blue', linestyle='-', linewidth=2, label='sin(x)') # 蓝色实线 plt.plot(x, y2, color='red', linestyle='--', linewidth=2, label='cos(x)') # 红色虚线 plt.legend(fontsize=12) # 设置图例字体大小 plt.show() ``` #### 3. 添加标记与注释 在关键点上添加标记和注释可以帮助读者更好地理解数据。例如: ```python plt.figure(figsize=(8, 6)) plt.plot(x, y1, color='blue', linestyle='-', linewidth=2, marker='o', markersize=5, label='sin(x)') plt.plot(x, y2, color='red', linestyle='--', linewidth=2, marker='s', markersize=5, label='cos(x)') # 添加注释 plt.annotate('Max of sin(x)', xy=(np.pi/2, 1), xytext=(2, 1.5), arrowprops=dict(facecolor='black', shrink=0.05)) plt.legend(fontsize=12) plt.show() ``` #### 4. 设置坐标轴标签与标题 清晰的坐标轴标签和标题是科研图表的重要组成部分。可以通过`xlabel`、`ylabel`和`title`函数进行设置: ```python plt.figure(figsize=(8, 6)) plt.plot(x, y1, color='blue', linestyle='-', linewidth=2, label='sin(x)') plt.plot(x, y2, color='red', linestyle='--', linewidth=2, label='cos(x)') plt.xlabel('X-axis Label', fontsize=14) # 设置x轴标签 plt.ylabel('Y-axis Label', fontsize=14) # 设置y轴标签 plt.title('High-Quality Line Plot for Scientific Research', fontsize=16) # 设置标题 plt.legend(fontsize=12) plt.show() ``` #### 5. 使用高级美学设计 为了进一步提升图表质量,可以参考美学色彩搭配理论,选择合适的配色方案[^3]。例如,使用Seaborn库中的调色板: ```python import seaborn as sns sns.set_style("whitegrid") # 设置背景风格 colors = sns.color_palette("husl", 2) # 生成两种颜色 plt.figure(figsize=(8, 6)) plt.plot(x, y1, color=colors[0], linestyle='-', linewidth=2, label='sin(x)') plt.plot(x, y2, color=colors[1], linestyle='--', linewidth=2, label='cos(x)') plt.legend(fontsize=12) plt.show() ``` #### 6. 导出高质量图像 最后,确保以高分辨率保存图像,以便用于科研论文或展示。可以使用`savefig`函数: ```python plt.savefig('high_quality_line_plot.png', dpi=300, bbox_inches='tight') ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值