Python之1960到2019全球前八GDP柱状图绘制


前言

为了数据方便观察,于是python对数据进行了图形可视化


一.工具:python里的pytcharts库

from pyecharts.options import LabelOpts, TitleOpts
from pyecharts.charts import Bar, Timeline

二.演示:

三.代码


# 读取数据按行读取
f = open(
    "1960-2019全球GDP数据.csv",
    "r", encoding="GB2312")
data_lines = f.readlines()
# 关闭文件
f.close()
# 删除第一行无用数据
data_lines.pop(0)
# 将数据转换为字典储存
# {年份:[[国家,gdp],[国家,gdp]],年份:[[国家,gdp],[国家,gdp]]}
# 先定义一个字典对象
data_dict = {}
for line in data_lines:
    # 年份, 国家 Gdp
    year = int(line.split(",")[0])
    country = line.split(",")[1]
    gdp = float(line.split(",")[2])
    # 如何判断字典里面是否有指定的key呢?
    try:
        data_dict[year].append([country, gdp])  # 如果有key,嵌套country,gdp
    except KeyError:
        data_dict[year] = []  # 如何没有新创建一个列表
        data_dict[year].append([country, gdp])
# print(data_dict)
# 创建时间线,设置主题,设置标题
timeline = Timeline()
# 排序年份
sorted_year_list = sorted(data_dict.keys())

# 按顺序循环奶年份
for year in sorted_year_list:
    # 对每年里面的数据进行排序按从大到小的方式,关键字传参
    data_dict[year].sort(key=lambda element: element[1], reverse=True)
    year_data = data_dict[year][0:8]
    Y_data = []
    X_data = []
    for country_gdp in year_data:
        X_data.append(country_gdp[0])  # x轴添加国家
        Y_data.append(country_gdp[1] / 1000000000)  # y轴添加GDP数据

    # 构建柱状图
    bar = Bar()
    X_data.reverse()  # 翻转数据
    Y_data.reverse()  #
    bar.add_xaxis(X_data)
    bar.add_yaxis("GDP(亿)", Y_data, label_opts=LabelOpts(position="right"))
    # 翻转坐标轴
    bar.reversal_axis()
    # 设置每一年的标题
    bar.set_global_opts(title_opts=TitleOpts(title=f"{year}全球前8GDP数据"))
    timeline.add(bar, str(year))

# 设置自动播放
timeline.add_schema(

    play_interval=500,
    is_timeline_show=True,  # 是否显示
    is_auto_play=True,  # 是否自动播放
    is_loop_play=False,  # 是否循环播放
)
# 绘图
timeline.render("1960-2019全球GDP前八.html")

实现非常简单,望自行体会

  • 7
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
好的,我可以为您提供一些参考代码和步骤,来绘制散点图、折线图和柱状图。 首先,我们需要使用Python的pandas和matplotlib库来处理和可视化数据。假设您已经将2021年各国GDP数据保存在一个名为“gdp.xlsx”的Excel文件中,并将其保存在与您的Python代码相同的目录中。 步骤1:导入必要的库 ```python import pandas as pd import matplotlib.pyplot as plt ``` 步骤2:读取Excel文件并处理数据 ```python # 读取Excel文件 df = pd.read_excel('gdp.xlsx', sheet_name='Sheet1') # 选择需要绘制数据列 countries = df['Country'] gdp_values = df['GDP'] # 打印数据 print(countries) print(gdp_values) ``` 步骤3:绘制散点图 ```python # 设置图形大小和标题 plt.figure(figsize=(10, 6)) plt.title('2021 GDP') # 绘制散点图 plt.scatter(countries, gdp_values) # 设置x轴标签旋转角度 plt.xticks(rotation=90) # 显示图形 plt.show() ``` 步骤4:绘制折线图 ```python # 设置图形大小和标题 plt.figure(figsize=(10, 6)) plt.title('2021 GDP') # 绘制折线图 plt.plot(countries, gdp_values) # 设置x轴标签旋转角度 plt.xticks(rotation=90) # 显示图形 plt.show() ``` 步骤5:绘制柱状图 ```python # 设置图形大小和标题 plt.figure(figsize=(10, 6)) plt.title('2021 GDP') # 绘制柱状图 plt.bar(countries, gdp_values) # 设置x轴标签旋转角度 plt.xticks(rotation=90) # 显示图形 plt.show() ``` 这样,您就可以使用Python绘制散点图、折线图和柱状图了。当然,您还可以使用其他库和方法来进行数据处理和可视化,这里只是提供一种参考。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值