GithubHelp home page GithubHelp logo

zeroyou / vnpy Goto Github PK

View Code? Open in Web Editor NEW

This project forked from vnpy/vnpy

0.0 3.0 0.0 104.98 MB

基于Python的开源量化交易平台开发框架

Home Page: http://www.vnpy.com

License: MIT License

Python 14.28% Batchfile 0.01% Shell 0.01% Jupyter Notebook 2.85% C++ 62.87% C 19.98% Objective-C 0.01%

vnpy's Introduction

By Traders, For Traders.

vn.py是一套基于Python的开源量化交易系统开发框架,自2015年1月正式发布以来,在开源社区5年持续不断的贡献下一步步成长为全功能量化交易平台,目前国内外金融机构用户已经超过300家,包括:私募基金、证券自营和资管、期货资管和子公司、高校研究机构、自营交易公司、交易所、Token Fund等。

2.0版本基于Python 3.7全新重构开发,目前功能还在逐步完善中。如需Python 2上的版本请点击:长期支持版本v1.9.2 LTS

功能特点

  1. 全功能量化交易平台(vnpy.trader),整合了多种交易接口,并针对具体策略算法和功能开发提供了简洁易用的API,用于快速构建交易员所需的量化交易应用。

  2. 覆盖国内外所有交易品种的交易接口(vnpy.gateway):

    • CTP(ctpGateway):国内期货、期权

    • 富途证券(futuGateway):港股、每股

    • Interactive Brokers(ibGateway):全球证券、期货、期权、外汇等

    • BitMEX (bitmexGateway):数字货币期货、期权、永续合约

  3. 开箱即用的各类量化策略交易应用(vnpy.app):

    • CtaStrategy:CTA策略引擎模块,在保持易用性的同时,允许用户针对CTA类策略运行过程中委托的报撤行为进行细粒度控制(降低交易滑点、实现高频策略)
  4. Python交易API接口封装(vnpy.api),提供上述交易接口的底层对接实现。

  5. 简洁易用的事件驱动引擎(vnpy.event),作为事件驱动型交易程序的核心。

  6. 社区论坛知乎专栏,内容包括vn.py项目的开发教程和Python在量化交易领域的应用研究等内容。

  7. 官方交流群262656087(QQ),管理严格(定期清除长期潜水的成员),入群费将捐赠给vn.py社区基金。

环境准备

  • 推荐使用vn.py团队为量化交易专门打造的Python发行版VNConda-2.0-Windows-x86_64,内置了最新版的vn.py,无需手动安装
  • 支持的系统版本:Windows 7以上/Windows Server 2008以上/Ubuntu 18.04 LTS
  • 支持的Python版本:Python 3.7 64位(注意必须是Python 3.7 64位版本
  • 如需使用IB API,请在Interactive Brokers Github页面下载安装IB API Latest

安装步骤

这里下载最新版本,解压后运行以下命令安装:

Windows

install.bat

Ubuntu

bash install.sh

使用指南

  1. SimNow注册CTP仿真账号,并在该页面获取经纪商代码以及交易行情服务器地址。

  2. vn.py社区论坛注册获得VN Station账号密码,论坛最新的注册邀请码为El86Pa1p

  3. 启动VN Station(安装VNConda后会在桌面自动创建快捷方式),输入上一步的账号密码登录

  4. 点击底部的VN Trader按钮,选择运行目录(默认在系统用户目录即可)后,在对话框中勾选CTP接口以及CtaStrategy应用,点击右下方的启动按钮,开始你的交易!!!

  5. 在VN Trader的运行过程中请勿关闭VN Station(会自动退出)

  6. 如选择了VNConda以外的安装方式(不推荐新手),可以在任意目录下创建run.py,写入以下示例代码后运行:

from vnpy.event import EventEngine
from vnpy.trader.engine import MainEngine
from vnpy.trader.ui import MainWindow, create_qapp
from vnpy.gateway.ctp import CtpGateway
from vnpy.app.cta_strategy import CtaStrategyApp

def main():
    """启动VN Trader"""
    qapp = create_qapp()

    event_engine = EventEngine()
    main_engine = MainEngine(event_engine)
    
    main_engine.add_gateway(CtpGateway)
    main_engine.add_app(CtaStrategyApp)

    main_window = MainWindow(main_engine, event_engine)
    main_window.showMaximized()

    qapp.exec()

if __name__ == "__main__":
    main()

贡献代码

vn.py使用github托管其源代码,如果希望贡献代码请使用github的PR(Pull Request)的流程:

  1. 创建 Issue - 对于较大的改动(如新功能,大型重构等)最好先开issue讨论一下,较小的improvement(如文档改进,bugfix等)直接发PR即可

  2. Fork vn.py - 点击右上角Fork按钮

  3. Clone你自己的fork: git clone https://github.com/$userid/vnpy.git

  4. dev创建你自己的feature branch: git checkout -b $my_feature_branch dev

  5. 在$my_feature_branch上修改并将修改push到你的fork上

  6. 创建从你的fork的$my_feature_branch分支到主项目的dev分支的[Pull Request] - 在此点击compare across forks,选择需要的fork和branch创建PR

  7. 等待review, 需要继续改进,或者被Merge!

在提交代码的时候,请遵守以下规则,以提高代码质量:

  • 使用autopep8格式化你的代码。运行autopep8 --in-place --recursive . 即可。
  • 使用flake8检查你的代码,确保没有error和warning。在项目根目录下运行flake8即可。

项目捐赠

过去5年中收到过许多社区用户的捐赠,在此深表感谢!所有的捐赠资金都投入到了vn.py社区基金中,用于支持vn.py项目的运作。

先强调一下:vn.py是开源项目,可以永久免费使用,并没有强制捐赠的要求!!!

捐赠方式:支付宝[email protected](*晓优)

长期维护捐赠清单,请在留言中注明是项目捐赠以及捐赠人的名字。

其他内容

版权说明

MIT

vnpy's People

Contributors

1122455801 avatar baiyanhuang avatar bigtan avatar border avatar cccbbbaaab avatar chenxy123 avatar cooooo avatar crystalphi avatar freeitaly avatar gwill avatar hackerwei avatar joans321 avatar lamter avatar lhzw avatar lyic avatar mhxueshan avatar nanoric avatar shaoupipi avatar shenzhuoheng avatar shinny-yangyang avatar sniper24 avatar tesla1060 avatar victorzsl avatar vnpy avatar vnpy-dev-01 avatar williamjqk avatar wisfern avatar xiaobear250 avatar xldistance avatar zhu4ling3 avatar

Watchers

 avatar  avatar  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.