Skip to main content

An Extensions help you streaming with real-time data

Project description


Shioaji Realtime Kline Extension

An Extensions help you streaming with real-time data

Contributors Stargazers Issues PyPI Latest Release PyPI Downloads

Table Of Contents

About The Project

When you use Shioaji Python API for technical analysis, you may need real-time data, and in different time dimensions, this package can help you subscribe to tick data and convert it into Kbars type (exactly the same as Shioaji Kbars ), to assist you in converting from Kbars to use more immediate data.

If you have any ideas or suggestions, we sincerely welcome you to contact us via email, or by creating an issue.

Assuming this project has been of great help to you, you are welcome to support my continued efforts through the following means.

Donate with PayPal

ETH : 0xb25aD6A441E89cFCa7850bA47A0d74131374d616

Description

  1. To use the extension just initialize the object
import shioaji_realtime_kbars
Contracts = shioaji_realtime_kbars.ShioajiRealtimeKbars(api)
  1. Get the real-time Kbars data with function
shioaji_realtime_kbars.Kbars(
    contract: shioaji.contracts.BaseContract,
    period: str = '5min'
) -> shioaji.data.Kbars

:information_source: period format can refer to the pandas document.

:warning: If you using this extension, you start with the market is opened and transactions frequently time. The latest Kline will be a little error.

Example : I use this extension in 8:45:10 in future market. The 8:46 Kline will have a little error. Ths data after 8:47 will be correct. So run this extension before the market is opened.

Getting Started

This is an example of how you may give instructions on setting up your project locally.

pip install shioaji_realtime_kbars

Usage

kbars

Refer to the shioaji sample

import pandas as pd
kbars = api.kbars(
    contract=api.Contracts.Stocks["2330"], 
    start="2023-01-15", 
    end="2023-01-16", 
)
df = pd.DataFrame({**kbars})
df.ts = pd.to_datetime(df.ts)
df.tail(5)

Change to

Contracts = shioaji_realtime_kbars.ShioajiRealtimeKbars(api)
Contracts.subscribe(api.Contracts.Futures.MXF.MXFR1)
Contracts.subscribe(api.Contracts.Futures.TXF.TXFR1)

@api.on_tick_stk_v1()
def callback(exchange: Exchange, tick : TickSTKv1):
    Contracts.update(tick, "stk")

@api.on_tick_fop_v1()
def callback(exchange : Exchange, tick : TickFOPv1):
    Contracts.update(tick, "fop")
        
while True:
    MXFR1_1K = Contracts.kbars(api.Contracts.Futures.MXF.MXFR1, "1min")
    df = pd.DataFrame({**MXFR1_1K })
    df.ts = pd.to_datetime(df.ts)
    print(df.tail(2), end = "\n")
    MXFR1_5K = Contracts.kbars(api.Contracts.Futures.MXF.MXFR1, "5min")
    df = pd.DataFrame({**MXFR1_5K })
    df.ts = pd.to_datetime(df.ts)
    print(df.tail(2), end = "\n")

Callback funtion

shioaji_realtime_kbars.ShioajiRealtimeKbars.subscribe?

Signature:
shioaji_realtime_kbars.ShioajiRealtimeKbars.subscribe(
    contract: List[Union[shioaji.contracts.Option, shioaji.contracts.Future, shioaji.contracts.Stock, shioaji.contracts.Index]],
    last_days: int = 0,
    cb: Any = List[[callback_function, period]]
) -> None

Example

If you want to clearly write your strategy. You can refer to example

def strategy(period, kbars):
    print(period)
    df = pd.DataFrame({**kbars}, columns = ["ts", "Open", "High", "Low", "Close", "Volume", "Amount"])
    df.ts = pd.to_datetime(df.ts)

    ### Write your strategy here ###

    print(df.tail(5), end = "\n")

if __name__ == "__main__":

    api = sj.Shioaji(simulation = True)

    api.login(
        api_key=config.API_KEY, 
        secret_key=config.API_SECRET
    )

    Contracts = shioaji_realtime_kbars.ShioajiRealtimeKbars(api)
    Contracts.subscribe(api.Contracts.Futures.MXF.MXFR1, last_days = 3, cb = [[strategy, "1min"], [strategy, "5min"]])

    @api.on_tick_fop_v1()
    def callback(exchange : Exchange, tick : TickFOPv1):
        Contracts.update(tick, "fop")

    Event().wait()

Version

  • v1.1.0 (2024/2/27) Improve with memory allocation
  • v1.0.7 (2023/10/11) Add TSE, TFE simtrade filter, Fix kbars with no historical problem
  • v1.0.6 (2023/7/28) Fis display
  • v1.0.5 (2023/7/19) Add callback function
  • v1.0.4 (2023/7/17)
  • v1.0.3 (2023/6/30) Fix Stock kbars problem issue
  • v1.0.1 Fix Naming Problem
  • v1.0.0

Roadmap

See the open issues for a list of proposed features (and known issues).

Authors

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

shioaji_realtime_kbars-1.1.0.tar.gz (5.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

shioaji_realtime_kbars-1.1.0-py3-none-any.whl (5.7 kB view details)

Uploaded Python 3

File details

Details for the file shioaji_realtime_kbars-1.1.0.tar.gz.

File metadata

  • Download URL: shioaji_realtime_kbars-1.1.0.tar.gz
  • Upload date:
  • Size: 5.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.8

File hashes

Hashes for shioaji_realtime_kbars-1.1.0.tar.gz
Algorithm Hash digest
SHA256 cb568fc98b82bf91b32095e04ab8a540c91d735b3f18f358503612f877651b57
MD5 7b6e843e6e74d5e2a7797c06ffe8af26
BLAKE2b-256 1f829640a8ebcab35dda0d5083b2cfdb656edbdcaba2b7f6b9fad2574f0af821

See more details on using hashes here.

File details

Details for the file shioaji_realtime_kbars-1.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for shioaji_realtime_kbars-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 f7964be2730ee2e1de6371fa9bbc52b74e77c3c622037e8769a2ff1625177c11
MD5 d9670449f59a31603f5a6041e0153b3c
BLAKE2b-256 ecf468d144892177951aab7d33730a458255c41717383b6598c123a547a31495

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page