可视化 | Pyecharts动态绘制比特币近几年股价变迁

简介: 可视化 | Pyecharts动态绘制比特币近几年股价变迁

大家好,我是欧K

本期主要利用pyecharts给大家展示比特币近几年股价变迁,主要用到timeline函数,希望对你有所帮助。

先看看效果:

1. 导入模块

import datetime
import pandas as pd
from pyecharts import options as opts
from pyecharts.charts import Line,Timeline
from pyecharts.commons.utils import JsCode

升级 pyecharts 包:可视化部分需要用到 pyecharts==1.9.0,已安装其他低版本的需要升级,如果未安装过pyecharts,直接pip安装就是最新版本。
2. Pandas数据处理

2.1 读取数据

df = pd.read_csv('btc.csv')
df

结果:

2.2 截取序列时间数据

数据时间可以根据需要自行调整(以2019-09-01为例):

df['date'] = pd.to_datetime(df['date'], format='%Y-%m-%d')
df = df[(df['date'] >=pd.to_datetime('20190901'))]

结果:


3. Pyecharts动态图绘制

3.1 设置横坐标中坐标数据样式

Line.add_xaxis(list(df['date'])[0:i])
Line.add_yaxis(
    series_name="",
    y_axis=list(df['closep'])[0:i], is_smooth=True,is_symbol_show=False,
    linestyle_opts={
           'normal': {
               'width': 3,
               'shadowColor': 'rgba(0, 0, 0, 0.5)',
               'shadowBlur': 5,
               'shadowOffsetY': 10,
               'shadowOffsetX': 10,
               'curve': 0.5,
               'color': JsCode(color_js0)
           }
       },
    itemstyle_opts=opts.ItemStyleOpts(color=JsCode(color_js0)),
    markpoint_opts=opts.MarkPointOpts(
        data=[
            opts.MarkPointItem(
                name="high_price",
                value=f'{coordy_high}$',coord=[coordx,coordy_high],symbol=symbol,
                symbol_size=30,
                itemstyle_opts=opts.ItemStyleOpts(color='#FF8C00',border_color="#FFD700")
            )
        ],
        label_opts=opts.LabelOpts(font_size=18,color="#EB1934",font_weight="bold",position="right")
    ),
)

这里主要注意线型(linestyle)标记(markpoint)的设置。

3.2 设置全局样式

Line.set_global_opts(
    title_opts=opts.TitleOpts(
        title=f"btc每日收盘价({title_date})",
        pos_top="10%",
        pos_left="center",
        title_textstyle_opts=opts.TextStyleOpts(color="#0000FF", font_family='STKaiti', font_size=20),
    ),
    xaxis_opts=opts.AxisOpts(
        type_="time",
        max_=x_max,
        boundary_gap=False,
        axislabel_opts=opts.LabelOpts(color="#EB1934"),
        axisline_opts=opts.AxisLineOpts(
            is_show=True,
            linestyle_opts=opts.LineStyleOpts(width=2, color="#EB1934")
        ),
        axistick_opts=opts.AxisTickOpts(
            is_show=True,
            linestyle_opts=opts.LineStyleOpts(color="#EB1934"),
        ),
    ),
    yaxis_opts=opts.AxisOpts(
        type_="value",
        max_=y_max,
        position="left",
        axislabel_opts=opts.LabelOpts(color="#EB1934"),
        axisline_opts=opts.AxisLineOpts(
            is_show=True,
            linestyle_opts=opts.LineStyleOpts(width=2, color="#EB1934")
        ),
        axistick_opts=opts.AxisTickOpts(
            is_show=True,
            linestyle_opts=opts.LineStyleOpts(color="#EB1934"),
        ),
        splitline_opts=opts.SplitLineOpts(
            is_show=False, linestyle_opts=opts.LineStyleOpts(color="#EB1934")
        ),
    ),
)


效果:

3.3 添加背景图片

graphic_opts=[
                opts.GraphicImage(
                    graphic_item=opts.GraphicItem(
                        id_="logo", z=-10, bounding="raw", origin=[50, 100]
                    ),
                    graphic_imagestyle_opts=opts.GraphicImageStyleOpts(
                        image="coin.jpg",
                        width=900,
                        height=600,
                        opacity=0.2,
                    ),
                )
            ],

效果:

完。

END以上就是本期为大家整理的全部内容了,如果需要数据文件,可以在公众号后台回复 btc 获取喜欢的朋友可以点赞、点在看也可以分享让更多人知道

相关文章
|
移动开发 HTML5
html5掷骰子跳棋游戏源码
html5掷骰子跳棋游戏源码
741 1
html5掷骰子跳棋游戏源码
|
前端开发 数据库
node使用node-xlsx实现excel的下载与导入,保证你看的明明白白
node使用node-xlsx实现excel的下载与导入,保证你看的明明白白
|
存储 SQL 分布式计算
浅谈MPP数据库-Vertica
用过这块数据库3年时间,很多功能非常强大,POC做了很多数据库,查询性能可以说是最好的,推荐一下
2911 2
|
存储 API Docker
只需10分钟!就能用Flask,Docker和Jenkins部署机器学习模型
一杯茶的功夫部署完成机器学习模型!
3612 1
|
10月前
|
人工智能 数据可视化 程序员
史上最全盘点:一文告诉你低代码(Low-Code)是什么?为什么要用?
在后疫情时代,低代码(Low-Code)+ 人工智能(AI)的组合被认为是加速社会数字化转型的重要技术。低代码通过可视化和模型驱动的理念,结合云原生和多端体验技术,显著提升了开发效率和灵活性。它不仅让专业开发者受益,还使业务人员成为“平民开发者”,弥补了专业人才缺口。此外,低代码平台能够快速响应市场变化,帮助企业构建各种应用,如四川某制造企业仅用一个月就搭建出一套内部协作和生产监控系统。结合AI的能力,低代码平台还能实现智能化的建议和优化,进一步提升用户体验和开发速度。
|
10月前
|
前端开发 JavaScript
如何利用 CSS3 动画实现元素的淡入淡出效果?
在上述代码中,定义了一个名为 `fade-in` 的CSS类,其初始透明度为0,并设置了淡入的过渡效果。当通过JavaScript为元素添加 `active` 类时,元素的透明度变为1,实现淡入效果;当再次点击按钮移除 `active` 类时,元素又会逐渐淡出。通过这种方式,可以根据用户的操作灵活地控制元素的淡入淡出效果。
1302 60
|
11月前
|
前端开发 JavaScript 测试技术
React 错误边界 (Error Boundaries) 详解
【10月更文挑战第17天】在现代前端开发中,React 通过“错误边界”机制提高了应用的健壮性和用户体验。错误边界是一种特殊的 React 组件,能捕获并处理其子组件树中的 JavaScript 错误,防止应用因局部错误而整体崩溃。创建错误边界需实现 `static getDerivedStateFromError` 和 `componentDidCatch` 方法,分别用于更新状态和记录错误。正确使用错误边界,可以有效提升应用的稳定性和用户满意度。
717 62
|
10月前
|
JavaScript 前端开发 开发者
如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤
随着前端开发技术的快速发展,代码规范和格式化工具变得尤为重要。本文介绍了如何在 Visual Studio Code (VSCode) 中使用 ESLint 和 Prettier 检查代码规范并自动格式化 Vue.js 代码,包括安装插件、配置 ESLint 和 Prettier 以及 VSCode 设置的具体步骤。通过这些工具,可以显著提升编码效率和代码质量。
1914 4
|
11月前
|
JavaScript 前端开发 开发者
如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。
【10月更文挑战第9天】随着前端开发技术的发展,代码规范和格式化工具变得至关重要。本文介绍如何在 VSCode 中使用 ESLint 和 Prettier 检查并自动格式化 Vue.js 代码,提升团队协作效率和代码质量。通过安装插件、配置 ESLint 和 Prettier,以及设置 VSCode,实现代码实时检查和格式化,确保代码风格一致。
1798 2
|
小程序 开发者
Taro@3.x+Vue@3.x+TS开发微信小程序,使用自定义tabBar
本文介绍了如何在Taro项目中实现自定义tabBar。首先,在`app.config.ts`中设置`custom: true`并配置`tabBar`。
707 0
Taro@3.x+Vue@3.x+TS开发微信小程序,使用自定义tabBar