『玩转Streamlit』–查看K线的小工具

在金融市场分析中,查看不同交易对的 K 线数据是一项基础且重要的工作。

今天,我们就来学习如何使用 Streamlit 构建一个简单的 K 线查看小工具,让你能够方便地查看不同交易对在不同时间范围内的 K 线数据。

1. 环境准备

首先,确保已经安装了必要的库。

除了 Streamlit 用于构建界面,还需要pandas 用于数据处理,plotly 用于绘制 K 线图。

我们假设已经有Streamlit环境,只要安装:

```python
pip install pandas plotly
```

2. 数据获取

K线 数据我是从币安交易所(binance)获取的,其中的字段如下:

```python
self.safe_integer(ohlcv, 0),  # open time
self.safe_number(ohlcv, 1),  # open
self.safe_number(ohlcv, 2),  # high
self.safe_number(ohlcv, 3),  # low
self.safe_number(ohlcv, 4),  # close
self.safe_number(ohlcv, 5),  # volume
self.safe_integer(ohlcv, 6),  # close time
self.safe_number(ohlcv, 7),  # quote asset volume
self.safe_integer(ohlcv, 8),  # number of trades
self.safe_number(ohlcv, 9),  # taker buy base asset volume
self.safe_number(ohlcv, 10),  # taker buy quote asset volume
```

其中用于K线展示的主要是:open time(K线开始时间),open(开盘价),high(最高价),low(最低价),close(收盘价),volumn(成交量)几个字段。

采集数据使用币安的公开API即可,本文的重点不在这里,不详细叙述了。

通过API,采集了大约300多个永续合约的K线数据。

3. 构建streamlit界面

接下来,我们开始构建 Streamlit 界面。

界面主要包含两个部分:上半部分可以选择交易对信息和 K 线时间范围;

```python
st.header("查看Current-交易对K线")

st.selectbox("选择交易对:", key="symbol", options=options, on_change=update_symbol)
st.date_input(
    "时间范围:",
    (st.session_state.start_date, st.session_state.end_date),
    format="YYYY/MM/DD",
    key="symbol_date_range",
    on_change=update_date_range,
)
```

下半部分用tab页 分别展示数据和K线图。

```python
def tab_data():
    if st.button("重载数据"):
        read_data(st.session_state.symbol)

    data = st.session_state.data
    if len(data) == 0:
        return

    # 更新开始结束时间
    data_start = datetime.datetime.strptime(start, "%Y-%m-%d %H:%M:%S")
    data_end = datetime.datetime.strptime(end, "%Y-%m-%d %H:%M:%S")
    if st.session_state.start_date > data_end.date():
        st.session_state.start_date = data_start.date()

    if st.session_state.end_date < data_start.date():
        st.session_state.end_date = data_end.date()

    data = filter_data(data)

    st.dataframe(data)


def tab_plotly_graph():
    if st.button("重新绘图"):
        read_data(st.session_state.symbol)

    if len(st.session_state.data) == 0:
        return

    data = filter_data(st.session_state.data)

    # 数据量太大时,使用最新的2000条来绘图
    if len(data) > 2000:
        graph = KlinePlotlyGraph(data=data.iloc[-2000:], idc_data=None)
    else:
        graph = KlinePlotlyGraph(data=data, idc_data=None)

    fig = graph.figure(title=f"{st.session_state.symbol} - K线图")

    st.plotly_chart(fig)

tab1, tab2 = st.tabs(["数据", "图形"])
with tab1:
    tab_data()

with tab2:
    tab_plotly_graph()
```

代码中封装的一些读取数据,显示图表的函数,比较冗长,这里没有贴出来。

本文的重点其实是通过Streamlit来构造一个简单的K线查看页面,展示Streamlit强大的前端界面功能。

4. 运行应用

最后,运行一下这个简单的应用,看看效果如何。

『玩转Streamlit』--查看K线的小工具

5. 总结

通过以上步骤,我们成功使用 Streamlit 构建了一个简单的 K 线查看小工具。

这个工具不仅可以帮助我们快速查看不同交易对的 K 线数据,还提供了直观的可视化界面。

当然,在实际应用中,你可以根据需要进一步优化和扩展这个工具,例如从实时数据源获取数据、添加更多的技术指标分析等。

文章整理自互联网,只做测试使用。发布者:Lomu,转转请注明出处:https://www.it1024doc.com/6369.html

(0)
LomuLomu
上一篇 2025 年 1 月 14 日
下一篇 2025 年 1 月 14 日

相关推荐

  • Java 大视界 — 基于 Java 的大数据分布式存储在物联网设备数据存储与管理中的应用(231)

    💖亲爱的朋友们,热烈欢迎来到 青云交的博客 !能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也期待你毫无保留地分享独特见解,愿我们于此携手成长,共赴新程!💖 全网(微信公众号/CSDN/抖音/华为/支付宝/微博) :青云交 一、欢迎加入【福利社群】 点击快速加入1…

    未分类 2025 年 5 月 13 日
    20100
  • 数据结构-8.Java. 七大排序算法(下篇)

    ![排序算法图解](https://pic.it1024doc.com/csdn/202412/e7a5ab870db2dde966e37f2c83a37ae4.jpeg) > 本文将深入探讨排序算法的核心概念,由于篇幅限制,我们将分两部分进行讨论。今日的主题是归并排序,以及快速排序的非递归实现技巧。 > 专栏:Java-**数据结构** > 如有疑问,请在…

    2024 年 12 月 27 日
    31000
  • 如何做好软件架构师

    本文以个人视野聊下软件架构师的工作以及软件架构设计知识。做开发工作接近10年了,期间主要做Windows应用开发。在成熟的“华南区最大WPF团队”希沃白板呆了较长一段时间、后面从0到1构建Windows技术栈以及会议屏软件集,在软件设计这块自己成长了很多。之前整理过如何做好技术经理 – 唐宋元明清2188 – 博客园,这里梳理下自己的设计思维,算是自己阶段性…

    未分类 2025 年 1 月 12 日
    35800
  • 详解:订单履约系统规划

    大家好,我是汤师爷~ 什么是订单履约系统? 订单履约是从消费者下单支付到收到商品的全流程管理过程,包括订单接收、订单派单、库存分配、仓储管理和物流配送等环节,核心目标是确保商品准时、准确地送达消费者手中。 通过订单履约系统,消费者可以实时了解商品的物流状态和预计送达时间,并可以根据需求选择同城配送、快递或自提等多样化的履约方式。 对商家而言,订单履约系统可以…

    2025 年 1 月 14 日
    46300
  • 深入解析Java字节码操作指南

    ✨ 技术背景: 资深技术专家, 文学典籍平台(电脑端访问地址:,移动端可通过微信搜索“ 历代文学 ”小程序)首席架构师,拥有15年一线开发经验,精通Java核心技术,高并发系统设计,Spring生态与微服务架构,熟练运用Linux系统,VMware虚拟化及云原生技术Docker/Kubernetes,持续关注技术前沿发展,致力于将理论转化为落地解决方案。保持…

    2025 年 5 月 13 日
    19000

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-800-8888

在线咨询: QQ交谈

邮件:admin@example.com

工作时间:周一至周五,9:30-18:30,节假日休息

关注微信