数据可视化-折线图可视化

更新时间: 2024-03-25 22:45:33

# Python数据和Json数据的相互转化

# 导入json模块
import json

# 准备符合格式json格式要求的python数据
data = [{"name":"老王","age":16},{"name":"张三","age":20}]

# 通过json.dumps(data)方法把python数据转化为json数据
data = json.dumps(data)
print(json_str, type(json_str))
# [{"name": "\u8001\u738b", "age": 16}, {"name": "\u5f20\u4e09", "age": 20}] <class 'str'>

# 不使用ASCII来去转换它
json_str = json.dumps(data, ensure_ascii=False)
print(json_str, type(json_str))
# [{"name": "老王", "age": 16}, {"name": "张三", "age": 20}] <class 'str'>


# 通过json.loads(data)方法把json数据转化为python数据
data = json.loads(data)
print(data, type(data))
# [{'name': '老王', 'age': 16}, {'name': '张三', 'age': 20}] <class 'list'>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21

# pyecharts模块安装

pip install pyecharts

查看官方示例:
https://gallery.pyecharts.org

# pyecharts快速入门

# 基础折线图

# 导包,导入Line功能构建折线图对象
from pyecharts.charts import Line

# 得到折线图对象
line = Line()

# 添加x轴数据
line.add_xaxis(["中国","美国","英国"])

# 添加y轴数据
line.add_yaxis("GDP", [30, 20, 10])

# 生成图表
line.render()
1
2
3
4
5
6
7
8
9
10
11
12
13
14

然后就会生成一个叫 render.html 的文件,打开它就是折线图了。

# set_global_opts方法

这里全局配置可以通过set_global_opts方法来进行配置,相应的选项和选项的功能如下:

from pyecharts.options import TitleOpts

line.set_global_opts(
    title_opts = TitleOpts("测试", pos_left="center", pos_bottom="1%"),
    legend_opts = LegendOpts(is_show = True),
    toolbox_opts = ToolboxOpts(is_show = True),
    visualmap_opts = VisualMapOpts(is_show=True),
    tooltip_opts = TooltipOpts(is_show = True)
)
1
2
3
4
5
6
7
8
9

# 数据处理

import json

# 处理数据
f_us = open("D:/python/python-learn/资料/可视化案例数据/折线图数据/美国.txt", encoding="UTF-8")
us_data = f_us.read() # 美国的全部内容

# 去掉不符合JSON规范的开头
us_data = us_data.replace("jsonp_1629344292311_69436(","")
us_data = us_data[:-2]

# JSON转Python字典
us_dict = json.loads(us_data)

# 获取trend key
trend_data = us_dict['data'][0]['trend']

# 获取日期数据,用于x轴,取2020年(到315下标结束)
x_data = trend_data['updateDate'][:314]
# 获取确诊数据,用于y轴,取2020年(到315下标结束)
y_data = trend_data['list'][0]['data'][:314]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20

# 创建折线图

import json
from pyecharts.charts import Line
from pyecharts.options import TitleOpts,LabelOpts

# 处理数据
f_us = open("D:/python/python-learn/资料/可视化案例数据/折线图数据/美国.txt", encoding="UTF-8")
us_data = f_us.read() # 美国的全部内容

f_jp = open("D:/python/python-learn/资料/可视化案例数据/折线图数据/日本.txt", encoding="UTF-8")
jp_data = f_jp.read() # 日本的全部内容

f_in = open("D:/python/python-learn/资料/可视化案例数据/折线图数据/印度.txt", encoding="UTF-8")
in_data = f_in.read() # 印度的全部内容

# 去掉不符合JSON规范的开头
us_data = us_data.replace("jsonp_1629344292311_69436(","")
jp_data = jp_data.replace("jsonp_1629350871167_29498(","")
in_data = in_data.replace("jsonp_1629350745930_63180(","")

us_data = us_data[:-2]
jp_data = jp_data[:-2]
in_data = in_data[:-2]

# JSON转Python字典
us_dict = json.loads(us_data)
jp_dict = json.loads(jp_data)
in_dict = json.loads(in_data)

# 获取trend key
us_trend_data = us_dict['data'][0]['trend']
jp_trend_data = jp_dict['data'][0]['trend']
in_trend_data = in_dict['data'][0]['trend']


# 获取日期数据,用于x轴,取2020年(到315下标结束)
us_x_data = us_trend_data['updateDate'][:314]
jp_x_data = jp_trend_data['updateDate'][:314]
in_x_data = in_trend_data['updateDate'][:314]

# 获取确诊数据,用于y轴,取2020年(到315下标结束)
us_y_data = us_trend_data['list'][0]['data'][:314]
jp_y_data = jp_trend_data['list'][0]['data'][:314]
in_y_data = in_trend_data['list'][0]['data'][:314]

# 生成图表
line = Line()  # 构建折线图对象
# 添加x轴数据
line.add_xaxis(us_x_data) # x轴公用,所以使用一个国家的数据即可
# 添加y轴数据
line.add_yaxis("美国确诊人数", us_y_data, label_opts=LabelOpts(is_show=False))
line.add_yaxis("日本确诊人数", jp_y_data, label_opts=LabelOpts(is_show=False))
line.add_yaxis("印度确诊人数", in_y_data, label_opts=LabelOpts(is_show=False))

# 设置全局选项
line.set_global_opts(
    # 标题设置
    title_opts=TitleOpts(title="2020年美日印三国确诊人数对比折线图",pos_left="center",pos_bottom="1%")
)

# 调用render方法,生成图表
line.render()
# 关闭文件对象
f_us.close()
f_jp.close()
f_in.close()

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66