网站首页 > 技术文章 正文
大家好,我是【Python当打之年】
本期主要利用pyecharts教大家制作 2022卡塔尔世界杯小组赛赛事时间线图 ,希望对大家有所帮助。
先看看效果:
1. 数据
以下面格式为例,读取数据:
df_t = pd.read_table('data.txt',sep=' ')
2. Pyecharts绘图
2.1 导入绘图模块
from pyecharts.charts import *
from pyecharts import options as opts
2.2 数据处理
法国、英格兰、德国、西班牙、巴西、阿根廷格式用到rich 富文本设置方式:
for idx, row in df_t.iterrows():
msg = '{c|%s %s}\n{a|%s}\n{b|%s}' % (row['日期'],row['时间'], row['双方'], row['球场'])
l_item = opts.LineItem(
name=10,
value=counter,
symbol='emptyCircle',
symbol_size=10,
label_opts=opts.LabelOpts(
is_show=True,
font_size=16,
font_family='STXingkai',
position=position[counter%2],
formatter=msg,
rich = {
'a': {
'fontSize': 18,
'color': colors_t[0],
'fontWeight':'bold',
'align':position[(counter+1)%2],
},
'b': {
'fontSize': 15,
'color':colors_t[2],
'align':position[(counter+1)%2]},
'c': {
'fontSize': 15,
'color': colors_t[1],
'fontWeight':'bold',
'align':position[(counter+1)%2]}
}
)
)
)
2.3 绘制直线图
line = (
Line(init_opts=opts.InitOpts(theme='light',width='800px',height='2800px',bg_color='white'))
.add_xaxis([''])
.add_yaxis(
'',
y_data[::-1],
tooltip_opts=opts.TooltipOpts(is_show=False)
)
.set_global_opts(
xaxis_opts=opts.AxisOpts(is_show=False, type_='category'),
yaxis_opts=opts.AxisOpts(is_show=False, type_='category', max_=len(y_data)),
)
)
2.4 设置线型
linestyle_opts={
'normal': {
'width': 4, # 设置线宽
'color':'#1A237E',
'shadowColor': 'rgba(155, 18, 184, .3)', # 阴影颜色
'shadowBlur': 10, # 阴影大小
'shadowOffsetY': 10, # Y轴方向阴影偏移
'shadowOffsetX': 10, # x轴方向阴影偏移
}
},
itemstyle_opts={
'normal': {
'color':'red',
'shadowColor': 'rgba(155, 18, 184, .3)', # 阴影颜色
'shadowBlur': 10, # 阴影大小
'shadowOffsetY': 10, # Y轴方向阴影偏移
'shadowOffsetX': 10, # x轴方向阴影偏移
}
}
2.5 设置背景
graphic_opts=[
opts.GraphicGroup(
graphic_item=opts.GraphicItem(id_='1',left="center", top="center", z=-1),
children=[
opts.GraphicImage(graphic_item=opts.GraphicItem(id_="logo",left='center',z=-1),
graphic_imagestyle_opts=opts.GraphicImageStyleOpts(
image='https://search-operate.cdn.bcebos.com/e7c2273cc53746916aa6f9fd9b81d262.png',
width=600,
height=800,
opacity=0.2,)
)
]
)
]
2.6 设置标题
title_opts=opts.TitleOpts(
title='2022卡塔尔世界杯--小组赛',
subtitle='(制图@微信公众号:Python当打之年)',
pos_left='center', pos_top='1%',
title_textstyle_opts=opts.TextStyleOpts(color='#880E4F', font_size=28),
subtitle_textstyle_opts=opts.TextStyleOpts(color='#263238', font_size=14)
)
大功告成!!!
3. 更多内容
《可视化图鉴》源码:
https://www.heywhale.com/home/column/60e2740e3aeb9c0017b967a2
END
以上就是本期为大家整理的全部内容了,赶快练习起来吧,喜欢的朋友可以点赞、转发,也可以在评论区留言相互交流。文章首发公众号 “Python当打之年” ,每天都有python编程技巧推送,希望大家可以喜欢。
猜你喜欢
- 2024-10-31 ReactNative源码笔记——你知道几条?
- 2024-10-31 Echarts饼图展示车站客流占比图(车站客流分析)
- 2024-10-31 第76节 Canvas绘图(下)-前端开发之JavaScript-王唯
- 2024-10-31 前端开发者如何利用 CSS 实现酷炫的变色方案?
- 2024-10-31 html中滚动字体的设置(html字体滚动效果)
- 2024-10-31 熬夜总结了“HTML5画布”的知识点(共10条)
- 2024-10-31 CSS3线性渐变、阴影、缩放实现动画下雨效果
- 2024-10-31 CSS3被玩儿坏?下雨动画效果CSS就可以搞定
- 2024-10-31 HTML5(五)——Canvas API(h5canvas动画入门教程)
- 2024-10-31 CSS3 box-shadow实现背景动画(css背景视频)
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)