整理

上级 068380c1
"""
演示第三个图表:GDP动态柱状图开发
"""
from pyecharts.charts import Bar, Timeline from pyecharts.charts import Bar, Timeline
from pyecharts.options import * from pyecharts.options import *
from pyecharts.globals import ThemeType from pyecharts.globals import ThemeType
...@@ -14,12 +11,8 @@ data_lines = f.readlines() ...@@ -14,12 +11,8 @@ data_lines = f.readlines()
f.close() f.close()
# 删除第一条数据 # 删除第一条数据
data_lines.pop(0) data_lines.pop(0)
# 将数据转换为字典存储,格式为:
# { 年份: [ [国家, gdp], [国家,gdp], ...... ], 年份: [ [国家, gdp], [国家,gdp], ...... ], ...... }
# { 1960: [ [美国, 123], [中国,321], ...... ], 1961: [ [美国, 123], [中国,321], ...... ], ...... }
# 先定义一个字典对象 # 先定义一个字典对象
data_dict = {} data_dict = {}
bar_colors = ['#FF0000', '#00FF00', '#0000FF', '#FFFF00', '#00FFFF', '#FF00FF', '#C0C0C0', '#800080']
for line in data_lines: for line in data_lines:
year = (line.split(",")[0]) # 日期 year = (line.split(",")[0]) # 日期
country = line.split(",")[1] # 昵称 country = line.split(",")[1] # 昵称
...@@ -31,11 +24,12 @@ for line in data_lines: ...@@ -31,11 +24,12 @@ for line in data_lines:
data_dict[year] = [] data_dict[year] = []
data_dict[year].append([country, gdp]) data_dict[year].append([country, gdp])
# print(data_dict[1960])
# 创建时间线对象 # 创建时间线对象
timeline = Timeline({"theme": ThemeType.LIGHT}) timeline = Timeline()
# timeline = Timeline({"theme": ThemeType.ROMANTIC})
# 排序年份 # 排序年份
sorted_year_list = sorted(data_dict.keys()) sorted_year_list = sorted(data_dict.keys())
for year in sorted_year_list: for year in sorted_year_list:
data_dict[year].sort(key=lambda element: element[1], reverse=True) data_dict[year].sort(key=lambda element: element[1], reverse=True)
# 取出本年份前8名的国家 # 取出本年份前8名的国家
...@@ -50,34 +44,28 @@ for year in sorted_year_list: ...@@ -50,34 +44,28 @@ for year in sorted_year_list:
bar = Bar() bar = Bar()
x_data.reverse() x_data.reverse()
y_data.reverse() y_data.reverse()
# bar.add_xaxis(x_data)
# for i, (country, gdp,color) in enumerate(zip(x_data, y_data,bar_color_list)):
# bar.add_yaxis(
# series_name=country,
# yaxis_data=[gdp],
# label_opts=opts.LabelOpts(position="right", color=bar_color_list[i]),
# )
bar.add_xaxis(x_data) bar.add_xaxis(x_data)
bar.add_yaxis("红包数据", y_data, label_opts=LabelOpts(position="right")) colors=['rgba(128, 128, 128, 0.5)']
# bar.add_yaxis("红包数据", y_data, label_opts=LabelOpts(position="right"), itemstyle_opts=ItemStyleOpts(color=bar_color_list)) # colors=['rgba(128, 128, 128, 0.5)','red','red','red','red','red','red','red']
# 反转x轴和y轴 bar.add_yaxis("红包数据", y_data
, itemstyle_opts=opts.ItemStyleOpts(
# color="red"
color="blue"
)
, label_opts=LabelOpts(position="right"))
bar.reversal_axis() bar.reversal_axis()
# 设置每一天的图表的标题
bar.set_global_opts( bar.set_global_opts(
title_opts=TitleOpts(title=f"{year}-CSDN抢到红包累计排名") title_opts=TitleOpts(title=f"{year}-CSDN抢到红包累计排名"),
) )
timeline.add(bar, str(year)) timeline.add(bar, str(year))
# for循环每一年的数据,基于每一年的数据,创建每一年的bar对象
# 在for中,将每一年的bar对象添加到时间线中
# 设置时间线自动播放 # 设置时间线自动播放
timeline.add_schema( timeline.add_schema(
play_interval=2000, play_interval=1500,
is_timeline_show=True, is_timeline_show=True,
is_auto_play=True, is_auto_play=True,
is_loop_play=False is_loop_play=False
) )
# 绘图 # 绘图
timeline.render("2023年11月11-2023年12月15每天CSDN抢到红包累计排名前8用户.html") timeline.render("颜色测试.html")
此差异已折叠。
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册