Code Monkey home page Code Monkey logo

shipane-python-sdk's Introduction

ShiPanE-Python-SDK

实盘易(ShiPanE)Python SDK,通达信自动化交易 API。

实盘易是爱股网旗下的股票自动化解决方案;提供基于 HTTP 协议的 RESTFul Service,从而管理通达信等交易终端。
交流QQ群:11527956 实盘易-股票自动交易

原理概述

  • 实盘易通过调用 WINDOWS API 对通达信进行操作。
  • 实盘易提供基于 HTTP 协议的 RESTFul Service/API。
  • SDK 对 API 进行了封装(由 shipane_sdk/client.py 中的 Client 类实现)。
  • 本地策略或量化交易平台(目前支持聚宽、米筐、优矿)的模拟交易通过调用 SDK 实现自动下单。

功能介绍

  • 简单的实盘易 HTTP API 封装,见 shipane_sdk/client.py
  • 多账号自动新股申购(自动打新)
  • 多账号自动逆回购
  • 定时批量下单
  • 聚宽(JoinQuant)集成
  • 米筐(RiceQuant) 集成
  • 优矿(Uqer)集成
  • 果仁(Guorn)集成

基本用法

import logging

import shipane_sdk

logging.basicConfig(level=logging.DEBUG)

client = shipane_sdk.Client(host='localhost', port=8888, key='')
account_info = client.get_account('title:monijiaoyi')
print(account_info)

详见:examples/basic_example.py

定时任务调度

  • 多账号自动新股申购(自动打新)
  • 聚宽(JoinQuant)自动跟单(抓取方式)
  • 米筐(RiceQuant) 自动跟单(抓取方式)
  • 优矿(Uqer)自动跟单(抓取方式)

Windows

安装

  • 安装 Python 3.5(建议安装 Anaconda3
  • cmd 中运行:pip install --no-binary shipane_sdk shipane_sdk
  • cmd 中运行:cd %UserProfile%\.shipane_sdk\config
  • cmd 中运行:echo No | copy /-Y scheduler-example.ini scheduler.ini

配置

  • cmd 中运行:explorer %UserProfile%\.shipane_sdk\config
  • 修改 scheduler.ini 中的配置(建议使用Notepad++)

运行

  • 找到 python 安装目录,例如:C:\Program Files\Anaconda3
  • cmd 下执行(具体路径自行修改):python "C:\Program Files\Anaconda3\Scripts\shipane-scheduler.py"

升级

  • cmd 中运行:pip install --upgrade --pre --no-deps --no-binary shipane_sdk shipane_sdk
  • 参考 scheduler-example.ini 修改 scheduler.ini

Mac/Linux

安装

  • 安装 Python 3.5
  • terminal 中运行:pip install --no-binary shipane_sdk shipane_sdk
  • terminal 中运行:cp -n ~/.shipane_sdk/config/scheduler-example.ini ~/.shipane_sdk/config/scheduler.ini

配置

  • 修改 ~/.shipane_sdk/config/scheduler.ini

运行

  • terminal 中运行:shipane-scheduler.py

升级

  • terminal 中运行:pip install --upgrade --no-deps --no-binary shipane_sdk shipane_sdk
  • 参考 scheduler-example.ini 修改 scheduler.ini

聚宽(JoinQuant)集成

一. 推送方式

适用于云服务器环境,例如阿里云;特点是稳定、高效,集成简单。

准备工作

  • 部署实盘易。
  • 本地测试通过。
  • 远程测试通过。

步骤

  • 将 shipane_sdk/client.py 上传至聚宽“投资研究”根目录,并重命名为 shipane_sdk.py。
  • 将 shipane_sdk/joinquant/executor.py 拷贝粘贴到 shipane_sdk.py 末尾。
  • 修改策略代码,可参考如下示例:
    • examples/joinquant/simple_strategy.py - 基本用法
    • examples/joinquant/new_stocks_purchase.py - 新股申购
    • examples/joinquant/repo.py - 逆回购

二. 抓取方式

无需云服务器,采用定时轮询的方式,实时性不如"推送方式"。

准备工作

  • 部署实盘易。
  • 测试通过。

步骤

定时任务调度

米筐(RiceQuant)集成

一. 推送方式

适用于云服务器环境,例如阿里云;特点是稳定、高效,集成简单。

准备工作

  • 部署实盘易。
  • 本地测试通过。
  • 远程测试通过。

步骤

  • 将 shipane_sdk/client.py 上传米筐“策略研究”根目录,并重命名为 shipane_sdk.py。
  • 将 shipane_sdk/ricequant/executor.py 拷贝粘贴到 shipane_sdk.py 末尾。
  • 修改策略代码,可参考如下示例:
    • examples/ricequant/simple_strategy.py - 基本用法
    • examples/ricequant/new_stocks_purchase.py - 新股申购
    • examples/ricequant/repo.py - 逆回购

二. 抓取方式

采用定时轮询的方式。

准备工作

  • 部署实盘易。
  • 测试通过。

步骤

定时任务调度

优矿(Uqer)集成

一. 推送方式

适用于云服务器环境,例如阿里云;特点是稳定、高效,集成简单。
开发中,暂不支持。

二. 抓取方式

采用定时轮询的方式。

准备工作

  • 部署实盘易。
  • 测试通过。

步骤

定时任务调度

果仁(Guorn)集成

一. 推送方式

不支持。

二. 抓取方式

采用定时轮询的方式。

准备工作

  • 部署实盘易。
  • 测试通过。

步骤

定时任务调度

字段要求

资金 包含以下字段

  • 可用

股份 包含以下字段

  • 证券数量

    正则:(证券|股份)(数量|余额)

    示例:证券数量、股份余额

  • 可卖数量

    正则:(可卖|可用)(数量|余额)

    示例:可卖数量、可用数量

  • 当前价

    正则:(当前|最新|参考市)价

    示例:当前价、最新价

字段映射可通过实盘易进行设置。详见:实盘易3.6.0.0自定义字段映射使用说明

其他语言 SDK

C# SDK

由网友 @YBO(QQ:259219140)开发。

shipane-python-sdk's People

Contributors

pyangs avatar sinall avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.