Author:龙箬
数据科学与大数据技术专业
用数据改变世界!
CSDN@weixin_43975035
我思故我在
由于腾讯疫情数据源的不断更新,本实验代码根据https://blog.csdn.net/qq_43613793/article/details/104356935
进行修改而成。
实验步骤及代码如下:
首先程序里面用到的世界各国中英文对照.xlsx
链接: https://pan.baidu.com/s/1ovfPVTpHxlxOGkCf8PXsHQ .
提取码:znbh
1.数据抓取:
数据源:链接: 腾讯实时疫情数据.
import json
import requests
import pandas as pd
from pyecharts.charts import *
from pyecharts import options as opts
from pyecharts.commons.utils import JsCode
from pyecharts.globals import ThemeType, ChartType
from bs4 import BeautifulSoup
reponse = requests.get('https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5').json()
data = json.loads(reponse['data'])
reponse1 = requests.get('https://view.inews.qq.com/g2/getOnsInfo?name=disease_other').json()
data1 = json.loads(reponse1['data'])
# 国内
lastUpdateTime = data['lastUpdateTime']
chinaTotal = data['chinaTotal']
chinaTotal['确诊'] = chinaTotal['confirm']
chinaTotal['疑似'] = chinaTotal['suspect']
chinaTotal['死亡'] = chinaTotal['dead']
chinaTotal['治愈'] = chinaTotal['heal']
chinaTotal['现有确诊'] = chinaTotal['nowConfirm']
chinaTotal['现有重症'] = chinaTotal['nowSevere']
del chinaTotal['confirm']
del chinaTotal['suspect']
del chinaTotal['dead']
del chinaTotal['heal']
del chinaTotal['nowConfirm']
del chinaTotal['nowSevere']
sum = chinaTotal['确诊'] + chinaTotal['疑似'] + chinaTotal['死亡'] + chinaTotal['治愈']
chinaAdd = data['chinaAdd']
chinaAdd['新增确诊'] = data['chinaAdd']['confirm']
chinaAdd['新增疑似'] = data['chinaAdd']['suspect']
chinaAdd['新增死亡'] = data['chinaAdd']['dead']
chinaAdd['新增治愈'] = data['chinaAdd']['heal']
chinaAdd['新增确诊'] = chinaAdd['nowConfirm']
chinaAdd['新增重症'] = chinaAdd['nowSevere']
del chinaAdd['confirm']
del chinaAdd['suspect']
del chinaAdd['dead']
del chinaAdd['heal']
del chinaAdd['nowConfirm']
del chinaAdd['nowSevere']
areaTree = data['areaTree']
china_data = areaTree[0]['children']
china_list = []
for x in range(len(china_data)):
province = china_data[x]['name']
province_list = china_data[x]['children']
for y in range(len(province_list)):
city = province_list[y]['name']
total = province_list[y]['total']
today = province_list[y]['today']
china_dict = {'province': province, 'city': city, 'total': total, 'today': today}
china_list.append(china_dict)
# 定义数据处理函数
def confirm(x):
confirm = eval(str(x))['confirm']
return confirm
def suspect(x):
suspect = eval(str(x))['suspect']
return suspect
def dead(x):
dead = eval(str(x))['dead']
return dead
def heal(x):
heal = eval(str(x))['heal']
return heal
def confirmCuts(x):
confirmCuts = eval(str(x))['confirmCuts']
return confirmCuts
def deadRate(x):
deadRate=eval(str(x))['deadRate']
return deadRate
def healRate(x):
healRate=eval(str(x))['healRate']
return healRate
china_data = pd.DataFrame(china_list)
print(china_list)
# 函数映射
china_data['confirm'] = china_data['total'].map(confirm)
china_data['suspect'] = china_data['total'].map(suspect)
china_data['dead'] = china_data['total'].map(dead)
china_data['heal'] = china_data['total'].map(heal)
china_data['deadRate']=china_data['total'].map(deadRate)
china_data['healRate']=china_data['total'].map(healRate)
china_data['addconfirm'] = china_data['today'].map(confirm)
china_data['addconfirmCuts'] = china_data['today'].map(confirmCuts)
china_data = china_data[
["province", "city", "confirm", "suspect", "dead", "heal","deadRate","healRate", "addconfirm", "addconfirmCuts"]]
china_data.head()
global_data = pd.DataFrame(data['areaTree'])
global_data['confirm'] = global_data['total'].map(confirm)
global_data['suspect'] = global_data['total'].map(suspect)
global_data['dead'] = global_data['total'].map(dead)
global_data['deadRate']=global_data['total'].map(deadRate)
global_data['healRate']=global_data['total'].map(healRate)
global_data['heal'] = global_data['total'].map(heal)
global_data['addconfirm'] = global_data['today'].map(confirm)
world_name = pd.read_excel("C:\\Users\\lenovo\\Desktop\\数据分析\\世界各国中英文对照.xlsx")
global_data = pd.merge(global_data, world_name, left_on="name", right_on="中文", how="inner")
global_data = global_data[
["name", "英文", "confirm", "suspect", "dead", "heal","deadRate","healRate", "addconfirm"]]
global_data.head()
# 日数据处理
chinaDayList = pd.DataFrame(data1['chinaDayList'])
chinaDayList = chinaDayList[['date', 'confirm', 'suspect', 'dead', 'heal']]
chinaDayList.head()
# 日新增数据处理
chinaDayAddList = pd.DataFrame(data1['chinaDayAddList'])
chinaDayAddList = chinaDayAddList[['date', 'confirm', 'suspect', 'dead', 'heal']]
chinaDayAddList.head()
# 饼图
total_pie = (
Pie(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, width='500px', height='350px', bg_color="transparent"))
.add("", [list(z) for z in zip(['确 诊 ', '疑 似 ', '死 亡 ', '治 愈 '], chinaTotal.values())],
center=["50%", "60%"], radius=[75, 100], )
.add("", [list(z) for z in zip(chinaAdd.keys(), chinaAdd.values())], center=["50%", "60%"], radius=[0, 50])
.set_global_opts(title_opts=opts.TitleOpts(title="全国总量", pos_bottom=0,
title_textstyle_opts=opts.TextStyleOpts(color="#00FFFF")),
legend_opts=opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="#FFFFFF")))
.set_series_opts(label_opts=opts.LabelOpts(formatter="{b}:{c}")))
#全球疫情地图,此部分目前画的不好,后续改进
world_map = (
Map(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS))
.add("", [list(z) for z in zip(list(global_data["英文"]), list(global_data["confirm"]))], "world",
is_map_symbol_show=False)
.set_series_opts(label_opts=opts.LabelOpts(is_show=False),
toolbox_opts=opts.ToolboxOpts(orient='vertical', pos_right="10%"))
.set_global_opts(visualmap_opts=opts.VisualMapOpts(is_piecewise=True, background_color="transparent",
textstyle_opts=opts.TextStyleOpts(color="#F5FFFA"),
pieces=[
{"min": 101, "label": '>100', "color": "#893448"},
{"min": 10, "max": 100, "label": '10-100',
"color": "#fb8146"},
{"min": 1, "max": 9, "label": '1-9',
"color": "#fff2d1"},
])))
# 中国疫情地图绘制
area_data = china_data.groupby("province")["confirm"].sum().reset_index()
area_data.columns = ["province", "confirm"]
area_map = (
Map(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS))
.add("", [list(z) for z in zip(list(area_data["province"]), list(area_data["confirm"]))], "china",
is_map_symbol_show=False, label_opts=opts.LabelOpts(color="#fff"),
tooltip_opts=opts.TooltipOpts(is_show=True), zoom=1.2, center=[105, 30])
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts(title="中国疫情分布图", pos_top='5%',
title_textstyle_opts=opts.TextStyleOpts(color="#FF0000")),
visualmap_opts=opts.VisualMapOpts(is_piecewise=True, pos_right=0, pos_bottom=0,
textstyle_opts=opts.TextStyleOpts(color="#F5FFFA"),
pieces=[
{"min": 1001, "label": '>1000', "color": "#893448"},
{"min": 500, "max": 1000, "label": '500-1000',
"color": "#ff585e"},
{"min": 101, "max": 499, "label": '101-499',
"color": "#fb8146"},
{"min": 10, "max": 100, "label": '10-100',
"color": "#ffb248"},
{"min": 0, "max": 9, "label": '0-9',
"color": "#fff2d1"}])))
#热图及城市分布
city_data = china_data.groupby('city')['confirm'].sum().reset_index()
city_data.columns = ["city", "confirm"]
def is_city(item):
'''
判断一个城市能否在Geo地图上被找到
:param item: 城市名
:return: T/F
'''
lists_1 = []
lists_1.append(item)
lists_2 = [10]
geo = Geo()
geo.add_schema(maptype="china")
try:
geo.add("确诊城市", [list(z) for z in zip(lists_1, lists_2)])
return True
except Exception:
return False
city_index = []
i = 0
for item in city_data['city']:
if is_city(item) == False:
city_index.append(i)
i += 1
for x in city_index:
del (city_data['city'][x])
del (city_data['confirm'][x])
city_index_ = []
i = 0
for item in city_data['confirm']:
if item > 1000:
city_index_.append(i)
i += 1
serious_city = [] # 严重城市
serious_submit = [] # 严重人数
for y in city_index_:
serious_city.append(list(city_data['city'])[y])
serious_submit.append(list(city_data['confirm'])[y])
list_1 = ["拉萨"]
list_2 = [1]
area_heat_geo = (
Geo(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS, bg_color='transparent'))
.add_schema(maptype="china", zoom=1.2, center=[105, 30])
.add("确诊城市", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))], symbol_size=10)
.add("确诊城市", [list(z) for z in zip(list_1, list_2)], symbol_size=10) # 孤独拉萨
.add("确诊城市", [list(z) for z in zip(list(serious_city), list(serious_submit))], # 感染者超1000的城市
type_=ChartType.EFFECT_SCATTER, effect_opts=opts.EffectOpts(is_show=True, color="black",
symbol_size=30, scale=4, period=1))
.add("", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))],
type_=ChartType.HEATMAP)
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(
visualmap_opts=opts.VisualMapOpts(range_size=[0, 25, 50, 75, 100], max_=1000, orient='horizontal',
pos_bottom=0),
title_opts=opts.TitleOpts(title="中国疫情分布热图", pos_top='5%'),
legend_opts=opts.LegendOpts(pos_bottom='10%', pos_left=0)))
date = [] # 日期
confirmTotal = [] # 累计确诊
confirmAdd = [] # 新增确诊
suspectTotal = [] # 累计疑似
suspectAdd = [] # 新增疑似
deadTotal = [] # 累计死亡
deadAdd = [] # 新增死亡
healTotal = [] # 累计治愈
healAdd = [] # 新增治愈
deadRate = [] # 死亡率
healRate = [] # 治愈率
#每日数据趋势:
for j in data1['chinaDayAddList']:
confirmAdd.append(j['confirm'])
suspectAdd.append(j['suspect'])
deadAdd.append(j['dead'])
healAdd.append(j['heal'])
for k in data1['chinaDayList']:
date.append(k['date'])
confirmTotal.append(k['confirm'])
suspectTotal.append(k['suspect'])
deadTotal.append(k['dead'])
healTotal.append(k['heal'])
deadRate.append(k['deadRate'])
healRate.append(k['healRate'])
line_1 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计确诊", confirmTotal, yaxis_index=1, is_smooth=True,
tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_1 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日确诊", confirmAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.extend_axis(yaxis=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("确诊", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_1)
line_2 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计疑似", suspectTotal, yaxis_index=1, is_smooth=True,
tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_2 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日疑似", suspectAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("疑似", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_2)
line_3 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计死亡", deadTotal, yaxis_index=1, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_3 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日死亡", deadAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_3)
line_4 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.ROMA, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计治愈", healTotal, yaxis_index=1, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_4 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.ROMA, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日治愈", healAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("治愈",pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_4)
line = (
Line(init_opts=opts.InitOpts(theme=ThemeType.CHALK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("死亡率", deadRate, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}%"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡/治愈率",pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
lines = (
Line(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("治愈率", healRate, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}%"))
.extend_axis(yaxis=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}%")))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡/治愈率", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}%")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(line)
tl = (
Timeline(init_opts=opts.InitOpts(theme=ThemeType.WALDEN, bg_color="transparent"))
.add_schema(play_interval=5000, is_auto_play=True,width='70%',height='10%',pos_left='center',
linestyle_opts=opts.LineStyleOpts(),label_opts=opts.LabelOpts(position='bottom',color="white"))
.add(bar_1, "确诊")
.add(bar_2, "疑似")
.add(bar_3, "死亡")
.add(bar_4, "治愈")
.add(lines, "死亡/治愈率"))
big_title = (
Pie()
.set_global_opts(
title_opts=opts.TitleOpts(title="COVID-19",
title_textstyle_opts=opts.TextStyleOpts(font_size=40, color='#FFFFFF',
border_radius=True, border_color="white"),
pos_top=0)))
times = (
Pie()
.set_global_opts(
title_opts=opts.TitleOpts(subtitle=("截至 " + lastUpdateTime),
subtitle_textstyle_opts=opts.TextStyleOpts(font_size=13, color='#FFFFFF'),
pos_top=0))
)
confirms = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="确诊", pos_left='center', pos_top='center',
subtitle="(现有)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
confirms_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['确诊']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增: " + str(chinaAdd['新增确诊'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#00FFFF",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#00BFFF")
)))
suspects = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="疑似", pos_left='center', pos_top='center',
subtitle="(现有)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
suspects_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['疑似']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增疑似'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#FF00FF",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#EE82EE")
)))
deads = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="死亡", pos_left='center', pos_top='center',
subtitle="(累计)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
deads_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['死亡']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增死亡'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#FF0000",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#F08080")
)))
heals = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="治愈", pos_left='center', pos_top='center',
subtitle="(累计)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
heals_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['治愈']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增治愈'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#00FF00",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#98FB98")
)))
um=chinaTotal['确诊']+chinaTotal['疑似']+chinaTotal['死亡']+chinaTotal['治愈']
confirm_liquid = (
Liquid()
.add("确诊比例", [chinaTotal['确诊'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#00FFFF",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
suspect_liquid = (
Liquid()
.add("疑似比例", [chinaTotal['疑似'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#FF00FF",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
dead_liquid = (
Liquid()
.add("死亡比例", [chinaTotal['死亡'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#FF0000",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
heal_liquid = (
Liquid()
.add("治愈比例", [chinaTotal['治愈'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#00FF00",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
wc = (
WordCloud()
.add("", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))],
word_gap=0, word_size_range=[10, 30]))
# 图片汇总
page = (Page(page_title="COVID-19")
.add(total_pie)
.add(world_map)
.add(area_map)
.add(area_heat_geo)
#.add(bar)
.add(tl)
.add(big_title)
.add(times)
.add(confirms)
.add(confirms_people)
.add(suspects)
.add(suspects_people)
.add(deads)
.add(deads_people)
.add(heals)
.add(heals_people)
.add(confirm_liquid)
.add(suspect_liquid)
.add(dead_liquid)
.add(heal_liquid)
.add(wc)
).render('COVID-19 数据一览.html')
with open("COVID-19 数据一览.html", "r+", encoding='utf-8') as html:
html_bf = BeautifulSoup(html, 'lxml')
divs = html_bf.select('.chart-container')
divs[0][
'style'] = "width:411px;height:303px;position:absolute;top:5px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
divs[1][
"style"] = "width:605px;height:274px;position:absolute;top:36px;left:333px;border-style:solid;border-color:#444444;border-width:0px;"
divs[2][
"style"] = "width:309px;height:405px;position:absolute;top:313px;left:961px;border-style:solid;border-color:#444444;border-width:0px;"
divs[3][
"style"] = "width:305px;height:405px;position:absolute;top:310px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
divs[4][
"style"] = "width:646px;height:304px;position:absolute;top:312px;left:312px;border-style:solid;border-color:#444444;border-width:0px;"
divs[5][
"style"] = "width:250px;height:55px;position:absolute;top:2px;left:440px;border-style:solid;border-color:#444444;border-width:0px;"
divs[6][
"style"] = "width:200px;height:30px;position:absolute;top:11px;left:675px;border-style:solid;border-color:#444444;border-width:0px;"
divs[7][
'style'] = "width:60px;height:75px;position:absolute;top:5px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;border-radius:25px 0px 0px 0px"
divs[8][
"style"] = "width:130px;height:75px;position:absolute;top:5px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[9][
"style"] = "width:60px;height:75px;position:absolute;top:80px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[10][
"style"] = "width:130px;height:75px;position:absolute;top:80px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[11][
"style"] = "width:60px;height:75px;position:absolute;top:155px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[12][
"style"] = "width:130px;height:75px;position:absolute;top:155px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[13][
"style"] = "width:60px;height:75px;position:absolute;top:230px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[14][
"style"] = "width:130px;height:75px;position:absolute;top:230px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;border-radius:0px 0px 25px 0px"
divs[15][
"style"] = "width:160px;height:160px;position:absolute;top:-35px;left:920px;border-style:solid;border-color:#444444;border-width:0px;"
divs[16][
"style"] = "width:160px;height:160px;position:absolute;top:40px;left:865px;border-style:solid;border-color:#444444;border-width:0px;"
divs[17][
"style"] = "width:160px;height:160px;position:absolute;top:115px;left:920px;border-style:solid;border-color:#444444;border-width:0px;"
divs[18][
"style"] = "width:160px;height:160px;position:absolute;top:188px;left:865px;border-style:solid;border-color:#444444;border-width:0px;"
divs[19][
"style"] = "width:1280px;height:120px;position:absolute;top:600px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
body = html_bf.find("body")
body["style"] = "background-color:#333333;"
html_new = str(html_bf)
html.seek(0, 0)
html.truncate()
html.write(html_new)
html.close()
最后粘贴上可直接复制粘贴运行的完整源代码:
import json
import requests
import pandas as pd
from pyecharts.charts import *
from pyecharts import options as opts
from pyecharts.commons.utils import JsCode
from pyecharts.globals import ThemeType, ChartType
from bs4 import BeautifulSoup
# 抓取数据
reponse = requests.get('https://view.inews.qq.com/g2/getOnsInfo?name=disease_h5').json()
data = json.loads(reponse['data'])
reponse1 = requests.get('https://view.inews.qq.com/g2/getOnsInfo?name=disease_other').json()
data1 = json.loads(reponse1['data'])
# 国内
lastUpdateTime = data['lastUpdateTime']
chinaTotal = data['chinaTotal']
chinaTotal['确诊'] = chinaTotal['confirm']
chinaTotal['疑似'] = chinaTotal['suspect']
chinaTotal['死亡'] = chinaTotal['dead']
chinaTotal['治愈'] = chinaTotal['heal']
chinaTotal['现有确诊'] = chinaTotal['nowConfirm']
chinaTotal['现有重症'] = chinaTotal['nowSevere']
del chinaTotal['confirm']
del chinaTotal['suspect']
del chinaTotal['dead']
del chinaTotal['heal']
del chinaTotal['nowConfirm']
del chinaTotal['nowSevere']
sum = chinaTotal['确诊'] + chinaTotal['疑似'] + chinaTotal['死亡'] + chinaTotal['治愈']
chinaAdd = data['chinaAdd']
chinaAdd['新增确诊'] = data['chinaAdd']['confirm']
chinaAdd['新增疑似'] = data['chinaAdd']['suspect']
chinaAdd['新增死亡'] = data['chinaAdd']['dead']
chinaAdd['新增治愈'] = data['chinaAdd']['heal']
chinaAdd['新增确诊'] = chinaAdd['nowConfirm']
chinaAdd['新增重症'] = chinaAdd['nowSevere']
del chinaAdd['confirm']
del chinaAdd['suspect']
del chinaAdd['dead']
del chinaAdd['heal']
del chinaAdd['nowConfirm']
del chinaAdd['nowSevere']
areaTree = data['areaTree']
china_data = areaTree[0]['children']
china_list = []
for x in range(len(china_data)):
province = china_data[x]['name']
province_list = china_data[x]['children']
for y in range(len(province_list)):
city = province_list[y]['name']
total = province_list[y]['total']
today = province_list[y]['today']
china_dict = {'province': province, 'city': city, 'total': total, 'today': today}
china_list.append(china_dict)
# 定义数据处理函数
def confirm(x):
confirm = eval(str(x))['confirm']
return confirm
def suspect(x):
suspect = eval(str(x))['suspect']
return suspect
def dead(x):
dead = eval(str(x))['dead']
return dead
def heal(x):
heal = eval(str(x))['heal']
return heal
def confirmCuts(x):
confirmCuts = eval(str(x))['confirmCuts']
return confirmCuts
def deadRate(x):
deadRate=eval(str(x))['deadRate']
return deadRate
def healRate(x):
healRate=eval(str(x))['healRate']
return healRate
china_data = pd.DataFrame(china_list)
print(china_list)
# 函数映射
china_data['confirm'] = china_data['total'].map(confirm)
china_data['suspect'] = china_data['total'].map(suspect)
china_data['dead'] = china_data['total'].map(dead)
china_data['heal'] = china_data['total'].map(heal)
china_data['deadRate']=china_data['total'].map(deadRate)
china_data['healRate']=china_data['total'].map(healRate)
china_data['addconfirm'] = china_data['today'].map(confirm)
china_data['addconfirmCuts'] = china_data['today'].map(confirmCuts)
china_data = china_data[
["province", "city", "confirm", "suspect", "dead", "heal","deadRate","healRate", "addconfirm", "addconfirmCuts"]]
china_data.head()
global_data = pd.DataFrame(data['areaTree'])
global_data['confirm'] = global_data['total'].map(confirm)
global_data['suspect'] = global_data['total'].map(suspect)
global_data['dead'] = global_data['total'].map(dead)
global_data['deadRate']=global_data['total'].map(deadRate)
global_data['healRate']=global_data['total'].map(healRate)
global_data['heal'] = global_data['total'].map(heal)
global_data['addconfirm'] = global_data['today'].map(confirm)
world_name = pd.read_excel("C:\\Users\\lenovo\\Desktop\\数据分析\\世界各国中英文对照.xlsx")
global_data = pd.merge(global_data, world_name, left_on="name", right_on="中文", how="inner")
global_data = global_data[
["name", "英文", "confirm", "suspect", "dead", "heal","deadRate","healRate", "addconfirm"]]
global_data.head()
# 饼图
total_pie = (
Pie(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, width='500px', height='350px', bg_color="transparent"))
.add("", [list(z) for z in zip(['确 诊 ', '疑 似 ', '死 亡 ', '治 愈 '], chinaTotal.values())],
center=["50%", "60%"], radius=[75, 100], )
.add("", [list(z) for z in zip(chinaAdd.keys(), chinaAdd.values())], center=["50%", "60%"], radius=[0, 50])
.set_global_opts(title_opts=opts.TitleOpts(title="全国总量", pos_bottom=0,
title_textstyle_opts=opts.TextStyleOpts(color="#00FFFF")),
legend_opts=opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="#FFFFFF")))
.set_series_opts(label_opts=opts.LabelOpts(formatter="{b}:{c}")))
world_map = (
Map(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS))
.add("", [list(z) for z in zip(list(global_data["英文"]), list(global_data["confirm"]))], "world",
is_map_symbol_show=False)
.set_series_opts(label_opts=opts.LabelOpts(is_show=False),
toolbox_opts=opts.ToolboxOpts(orient='vertical', pos_right="10%"))
.set_global_opts(visualmap_opts=opts.VisualMapOpts(is_piecewise=True, background_color="transparent",
textstyle_opts=opts.TextStyleOpts(color="#F5FFFA"),
pieces=[
{"min": 101, "label": '>100', "color": "#893448"},
{"min": 10, "max": 100, "label": '10-100',
"color": "#fb8146"},
{"min": 1, "max": 9, "label": '1-9',
"color": "#fff2d1"},
])))
# 中国疫情地图绘制
area_data = china_data.groupby("province")["confirm"].sum().reset_index()
area_data.columns = ["province", "confirm"]
area_map = (
Map(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS))
.add("", [list(z) for z in zip(list(area_data["province"]), list(area_data["confirm"]))], "china",
is_map_symbol_show=False, label_opts=opts.LabelOpts(color="#fff"),
tooltip_opts=opts.TooltipOpts(is_show=True), zoom=1.2, center=[105, 30])
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts(title="中国疫情分布图", pos_top='5%',
title_textstyle_opts=opts.TextStyleOpts(color="#FF0000")),
visualmap_opts=opts.VisualMapOpts(is_piecewise=True, pos_right=0, pos_bottom=0,
textstyle_opts=opts.TextStyleOpts(color="#F5FFFA"),
pieces=[
{"min": 1001, "label": '>1000', "color": "#893448"},
{"min": 500, "max": 1000, "label": '500-1000',
"color": "#ff585e"},
{"min": 101, "max": 499, "label": '101-499',
"color": "#fb8146"},
{"min": 10, "max": 100, "label": '10-100',
"color": "#ffb248"},
{"min": 0, "max": 9, "label": '0-9',
"color": "#fff2d1"}])))
city_data = china_data.groupby('city')['confirm'].sum().reset_index()
city_data.columns = ["city", "confirm"]
def is_city(item):
'''
判断一个城市能否在Geo地图上被找到
:param item: 城市名
:return: T/F
'''
lists_1 = []
lists_1.append(item)
lists_2 = [10]
geo = Geo()
geo.add_schema(maptype="china")
try:
geo.add("确诊城市", [list(z) for z in zip(lists_1, lists_2)])
return True
except Exception:
return False
city_index = []
i = 0
for item in city_data['city']:
if is_city(item) == False:
city_index.append(i)
i += 1
for x in city_index:
del (city_data['city'][x])
del (city_data['confirm'][x])
city_index_ = []
i = 0
for item in city_data['confirm']:
if item > 1000:
city_index_.append(i)
i += 1
serious_city = [] # 严重城市
serious_submit = [] # 严重人数
for y in city_index_:
serious_city.append(list(city_data['city'])[y])
serious_submit.append(list(city_data['confirm'])[y])
list_1 = ["拉萨"]
list_2 = [1]
area_heat_geo = (
Geo(init_opts=opts.InitOpts(theme=ThemeType.WESTEROS, bg_color='transparent'))
.add_schema(maptype="china", zoom=1.2, center=[105, 30])
.add("确诊城市", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))], symbol_size=10)
.add("确诊城市", [list(z) for z in zip(list_1, list_2)], symbol_size=10) # 孤独拉萨
.add("确诊城市", [list(z) for z in zip(list(serious_city), list(serious_submit))], # 感染者超1000的城市
type_=ChartType.EFFECT_SCATTER, effect_opts=opts.EffectOpts(is_show=True, color="black",
symbol_size=30, scale=4, period=1))
.add("", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))],
type_=ChartType.HEATMAP)
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(
visualmap_opts=opts.VisualMapOpts(range_size=[0, 25, 50, 75, 100], max_=1000, orient='horizontal',
pos_bottom=0),
title_opts=opts.TitleOpts(title="中国疫情分布热图", pos_top='5%'),
legend_opts=opts.LegendOpts(pos_bottom='10%', pos_left=0)))
date = [] # 日期
confirmTotal = [] # 累计确诊
confirmAdd = [] # 新增确诊
suspectTotal = [] # 累计疑似
suspectAdd = [] # 新增疑似
deadTotal = [] # 累计死亡
deadAdd = [] # 新增死亡
healTotal = [] # 累计治愈
healAdd = [] # 新增治愈
deadRate = [] # 死亡率
healRate = [] # 治愈率
for j in data1['chinaDayAddList']:
confirmAdd.append(j['confirm'])
suspectAdd.append(j['suspect'])
deadAdd.append(j['dead'])
healAdd.append(j['heal'])
for k in data1['chinaDayList']:
date.append(k['date'])
confirmTotal.append(k['confirm'])
suspectTotal.append(k['suspect'])
deadTotal.append(k['dead'])
healTotal.append(k['heal'])
deadRate.append(k['deadRate'])
healRate.append(k['healRate'])
line_1 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计确诊", confirmTotal, yaxis_index=1, is_smooth=True,
tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_1 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日确诊", confirmAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.extend_axis(yaxis=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("确诊", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_1)
line_2 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计疑似", suspectTotal, yaxis_index=1, is_smooth=True,
tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_2 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日疑似", suspectAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("疑似", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_2)
line_3 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计死亡", deadTotal, yaxis_index=1, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_3 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.DARK, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日死亡", deadAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_3)
line_4 = (
Line(init_opts=opts.InitOpts(theme=ThemeType.ROMA, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("累计治愈", healTotal, yaxis_index=1, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
bar_4 = (
Bar(init_opts=opts.InitOpts(theme=ThemeType.ROMA, bg_color="#333333"))
.add_xaxis(date[7:])
.add_yaxis("单日治愈", healAdd, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("治愈",pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(
line_4)
line = (
Line(init_opts=opts.InitOpts(theme=ThemeType.CHALK, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("死亡率", deadRate, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}%"))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡/治愈率",pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white")))))
lines = (
Line(init_opts=opts.InitOpts(theme=ThemeType.LIGHT, bg_color="#333333"))
.add_xaxis(date)
.add_yaxis("治愈率", healRate, is_smooth=True, tooltip_opts=opts.TooltipOpts(formatter="{a}:{c}%"))
.extend_axis(yaxis=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}%")))
.set_series_opts(label_opts=opts.LabelOpts(is_show=False))
.set_global_opts(title_opts=opts.TitleOpts("死亡/治愈率", pos_left='10%',
title_textstyle_opts=opts.TextStyleOpts(color="white")),
yaxis_opts=opts.AxisOpts(axislabel_opts=opts.LabelOpts(formatter="{value}%")),
legend_opts=(opts.LegendOpts(textstyle_opts=opts.TextStyleOpts(color="white"))))).overlap(line)
tl = (
Timeline(init_opts=opts.InitOpts(theme=ThemeType.WALDEN, bg_color="transparent"))
.add_schema(play_interval=5000, is_auto_play=True,width='70%',height='10%',pos_left='center',
linestyle_opts=opts.LineStyleOpts(),label_opts=opts.LabelOpts(position='bottom',color="white"))
.add(bar_1, "确诊")
.add(bar_2, "疑似")
.add(bar_3, "死亡")
.add(bar_4, "治愈")
.add(lines, "死亡/治愈率"))
big_title = (
Pie()
.set_global_opts(
title_opts=opts.TitleOpts(title="COVID-19",
title_textstyle_opts=opts.TextStyleOpts(font_size=40, color='#FFFFFF',
border_radius=True, border_color="white"),
pos_top=0)))
times = (
Pie()
.set_global_opts(
title_opts=opts.TitleOpts(subtitle=("截至 " + lastUpdateTime),
subtitle_textstyle_opts=opts.TextStyleOpts(font_size=13, color='#FFFFFF'),
pos_top=0))
)
confirms = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="确诊", pos_left='center', pos_top='center',
subtitle="(现有)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
confirms_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['确诊']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增: " + str(chinaAdd['新增确诊'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#00FFFF",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#00BFFF")
)))
suspects = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="疑似", pos_left='center', pos_top='center',
subtitle="(现有)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
suspects_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['疑似']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增疑似'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#FF00FF",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#EE82EE")
)))
deads = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="死亡", pos_left='center', pos_top='center',
subtitle="(累计)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
deads_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['死亡']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增死亡'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#FF0000",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#F08080")
)))
heals = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title="治愈", pos_left='center', pos_top='center',
subtitle="(累计)",item_gap=1,
subtitle_textstyle_opts=opts.TextStyleOpts(color="#FFFFFF"),
title_textstyle_opts=opts.TextStyleOpts(color='#FFFFFF'))))
heals_people = (Pie().
set_global_opts(title_opts=opts.TitleOpts(title=(str(chinaTotal['治愈']) + " "),
pos_top='15%', pos_left='center',
subtitle=(" 新增 :" + str(chinaAdd['新增治愈'])),
item_gap=1,
title_textstyle_opts=opts.TextStyleOpts(color="#00FF00",
font_size=30),
subtitle_textstyle_opts=opts.TextStyleOpts(color="#98FB98")
)))
sum=chinaTotal['确诊']+chinaTotal['疑似']+chinaTotal['死亡']+chinaTotal['治愈']
confirm_liquid = (
Liquid()
.add("确诊比例", [chinaTotal['确诊'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#00FFFF",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
suspect_liquid = (
Liquid()
.add("疑似比例", [chinaTotal['疑似'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#FF00FF",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
dead_liquid = (
Liquid()
.add("死亡比例", [chinaTotal['死亡'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#FF0000",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
heal_liquid = (
Liquid()
.add("治愈比例", [chinaTotal['治愈'] / sum], tooltip_opts=opts.TooltipOpts(),
label_opts=opts.LabelOpts(color="#00FF00",
font_size=15,
formatter=JsCode(
"""function (param) {
return (Math.floor(param.value * 10000) / 100) + '%';
}"""
),
position="inside",
),
)
)
wc = (
WordCloud()
.add("", [list(z) for z in zip(list(city_data["city"]), list(city_data["confirm"]))],
word_gap=0, word_size_range=[10, 30]))
page = (Page(page_title="COVID-19")
.add(total_pie)
.add(world_map)
.add(area_map)
.add(area_heat_geo)
#.add(bar)
.add(tl)
.add(big_title)
.add(times)
.add(confirms)
.add(confirms_people)
.add(suspects)
.add(suspects_people)
.add(deads)
.add(deads_people)
.add(heals)
.add(heals_people)
.add(confirm_liquid)
.add(suspect_liquid)
.add(dead_liquid)
.add(heal_liquid)
.add(wc)
).render('C:\\Users\\lenovo\\Desktop\\数据分析\\COVID-19 数据一览.html')
with open("C:\\Users\\lenovo\\Desktop\\数据分析\\COVID-19 数据一览.html", "r+", encoding='utf-8') as html:
html_bf = BeautifulSoup(html, 'lxml')
divs = html_bf.select('.chart-container')
divs[0][
'style'] = "width:411px;height:303px;position:absolute;top:5px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
divs[1][
"style"] = "width:605px;height:274px;position:absolute;top:36px;left:333px;border-style:solid;border-color:#444444;border-width:0px;"
divs[2][
"style"] = "width:309px;height:405px;position:absolute;top:313px;left:961px;border-style:solid;border-color:#444444;border-width:0px;"
divs[3][
"style"] = "width:305px;height:405px;position:absolute;top:310px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
divs[4][
"style"] = "width:646px;height:304px;position:absolute;top:312px;left:312px;border-style:solid;border-color:#444444;border-width:0px;"
divs[5][
"style"] = "width:250px;height:55px;position:absolute;top:2px;left:440px;border-style:solid;border-color:#444444;border-width:0px;"
divs[6][
"style"] = "width:200px;height:30px;position:absolute;top:11px;left:675px;border-style:solid;border-color:#444444;border-width:0px;"
divs[7][
'style'] = "width:60px;height:75px;position:absolute;top:5px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;border-radius:25px 0px 0px 0px"
divs[8][
"style"] = "width:130px;height:75px;position:absolute;top:5px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[9][
"style"] = "width:60px;height:75px;position:absolute;top:80px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[10][
"style"] = "width:130px;height:75px;position:absolute;top:80px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[11][
"style"] = "width:60px;height:75px;position:absolute;top:155px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[12][
"style"] = "width:130px;height:75px;position:absolute;top:155px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[13][
"style"] = "width:60px;height:75px;position:absolute;top:230px;left:1060px;border-style:solid;border-color:#DC143C;border-width:3px;"
divs[14][
"style"] = "width:130px;height:75px;position:absolute;top:230px;left:1120px;border-style:solid;border-color:#DC143C;border-width:3px;border-radius:0px 0px 25px 0px"
divs[15][
"style"] = "width:160px;height:160px;position:absolute;top:-35px;left:920px;border-style:solid;border-color:#444444;border-width:0px;"
divs[16][
"style"] = "width:160px;height:160px;position:absolute;top:40px;left:865px;border-style:solid;border-color:#444444;border-width:0px;"
divs[17][
"style"] = "width:160px;height:160px;position:absolute;top:115px;left:920px;border-style:solid;border-color:#444444;border-width:0px;"
divs[18][
"style"] = "width:160px;height:160px;position:absolute;top:188px;left:865px;border-style:solid;border-color:#444444;border-width:0px;"
divs[19][
"style"] = "width:1280px;height:120px;position:absolute;top:600px;left:0px;border-style:solid;border-color:#444444;border-width:0px;"
body = html_bf.find("body")
body["style"] = "background-color:#333333;"
html_new = str(html_bf)
html.seek(0, 0)
html.truncate()
html.write(html_new)
html.close()
感谢腾讯实时提供更新疫情数据
感谢: sleepyyoung.博主的两篇文章
pyecharts实现新冠肺炎疫情可视化BI数据大屏.
pyecharts实现新冠肺炎疫情可视化并搭建BI数据大屏(Plus).
如有侵权,请联系侵删
需要本实验源数据的小伙伴请联系作者或联系QQ:2225872659