网站首页 > 技术文章 正文
大家好,我是【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背景视频)
- 最近发表
-
- count(*)、count1(1)、count(主键)、count(字段) 哪个更快?
- 深入探索 Spring Boot3 中 MyBatis 的 association 标签用法
- js异步操作 Promise fetch API 带来的网络请求变革—仙盟创梦IDE
- HTTP状态码超详细说明_http 状态码有哪些
- 聊聊跨域的原理与解决方法_跨域解决方案及原理
- 告别懵圈!产品新人的接口文档轻松入门指南
- 在Javaweb中实现发送简单邮件_java web发布
- 优化必备基础:Oracle中常见的三种表连接方式
- Oracle常用工具使用 - AWR_oracle工具有哪些
- 搭载USB 3.1接口:msi 微星 发布 990FXA Gaming 游戏主板
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- asynccallback (71)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)