Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

futuquant

Package Overview
Dependencies
Maintainers
1
Versions
14
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

futuquant

FutuQuant-Nodejs

  • 3.2.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
Maintainers
1
Weekly downloads
 
Created
Source

FutuQuant量化接口Nodejs版本

基于 FutuQuant v3.2 底层协议封装的nodejs版本接口,数据格式使用 protobuf,使用前请先在本地或者服务端启动 FutuOpenD 服务。

相关说明:

  • 使用了async/await语法,要求nodejs版本v7.10.1以上,v7.5.1以上可以使用--harmony或者--harmony-async-await参数开启async/await的支持,v7.6.x 以可以不用开启 flag 直接使用。。
  • 底层协议基于FutuQuant v3.2,参考:FutunnOpen/futuquant
  • 数据传输格式目前只支持protobuf。
  • API文档相关:https://yisbug.github.io/nodejs-for-FutuOpenD/doc/index.html

为了方便使用,请注意部分接口参数及返回结果和富途官方版本不完全一致,详细请参考API文档

更新

3.2.0 - 2018-8-15
  • opt: 修改版本号和官方 futuquant 的大版本号一致,即前两位3.2和官方保持一致,小版本号的更新用于bugfix 和其他的接口调整。
  • opt: 彻底去除 es6 modules,不再需要 babel 编译。
  • feat: 同步更新到官方最新版本 v3.2 。
  • feat: 增加 qotGetReference 获取正股相关股票接口
  • feat: 增加 trdGetMaxTrdQtys 获取最大交易数量接口
  • fix: 获取 k 线相关接口返回的数组增加兼容性支持。
  • feat: qotGetHistoryKLPoints 接口返回参数调整为直接返回数组
  • feat: qotGetTicker 接口返回参数调整为直接返回数组
  • feat: qotGetRT 接口返回参数调整为直接返回数组
0.2.0 - 2018.07.27
  • fix: 优化自定义logger部分
  • feat: 修改qotGetBasicQot方法直接返回数组
  • feat: 修改qotGetOrderBook方法直接返回对象,并增加sellList和buyList两个字段,等同于orderBookAskList和orderBookBidList
  • feat: 修改subQotUpdateOrderBook事件传递的摆盘结果,增加sellList和buyList两个字段,等同于orderBookAskList和orderBookBidList
  • feat: 修改qotGetBroker方法返回结果,增加sellList和buyList两个字段,等同于brokerAskList和brokerBidList
  • feat: 修改subQotUpdateBroker方法事件传递的经纪队列,增加sellList和buyList两个字段,等同于brokerAskList和brokerBidList
  • feat: 修改qotGetStaticInfo返回结果,直接返回数组
  • feat: 修改qotGetSecuritySnapShot返回结果,直接返回数组,并支持超过200支以上股票的查询。
  • feat: 新增按市价下单接口:trdPlaceOrderMarket(param),直到交易完成成功为止,返回买入/卖出总价
  • feat: 新增取消注册订单更新接口:unsubTrdUpdateOrder()
  • docs: 其他调整

更多请点击查看更新日志

安装

npm install futuquant --save

或者

yarn add futuquant

使用

/**
-  **所有行情相关协议获取数据都需要先通过(1005)协议订阅成功后才能查询**
-  **订阅的上限为500个订阅单位。一只股票的一个K线类型占2个订阅单位、分时占2个订阅单位、
-  报价占1个订阅单位、摆盘占5个订阅单位(牛熊为1)、逐笔占5个订阅单位(牛熊为1)、经纪队列占5个订阅单位(牛熊为1)。**
-  **反订阅(1006)的时间限制为1分钟,即订阅某支股票某个订阅位1分钟之后才能反订阅**
-  **30秒内不能超过20次交易请求。**
-  **建议所有行情拉取接口在同一条长连接上。推送数据在第二条长连接上。交易接口在第三条长连接上。**
 */
const fs = require('fs');
const path = require('path');
const FtQuant = require('./src/futuquant');

// 自定义日志对象
const bunyan = require('bunyan');
const bunyanDebugStream = require('bunyan-debug-stream');

const bunyanLogger = bunyan.createLogger({
  name: 'sys',
  streams: [{
    level: 'debug',
    type: 'raw',
    serializers: bunyanDebugStream.serializers,
    stream: bunyanDebugStream({ forceColor: true }),
  }],
});

// 从 opend 的配置文件中获取 userID,pwd
const FutuOpenDXMLPath = path.join(__dirname, '../FutuOpenD_1.01_Mac/FutuOpenD.xml');
const ftOpenDConfig = fs.readFileSync(FutuOpenDXMLPath);
const userID = ftOpenDConfig.match(/login_account>(\d*?)<\/login_account/)[1];
const pwdMd5 = ftOpenDConfig.match(/trade_pwd_md5>(.*?)<\/trade_pwd_md5/)[1];

// openD 配置
const ftConfig = {
  ip: '127.0.0.1',
  port: 11111,
  userID,
  market: 1, // 港股环境
  pwdMd5,
  env: 1, // 0为仿真,1为真实,默认为1。
};

const ft = new FtQuant(ftConfig, bunyanLogger);

const init = async () => {
  let res = null;
  await ft.init(); // 初始化 ft 模块
  res = await ft.getGlobalState(); // 获取全局状态
  console.log('getGlobalState', res);

  // 获取历史成交记录,不再需要手动解锁交易密码以及调用setCommonTradeHeader
  await ft.trdGetHistoryOrderFillList({
    beginTime: '2018-01-01 00:00:00',
    endTime: '2018-02-01 00:00:00',
  });
};

init();

测试

请先修改test/futuquant.test.jsFutuOpenDXMLPath的路径,然后执行npm installyarn安装相关依赖。

运行测试:

npm test

广告

如有需要,请填写推荐人牛牛号:5894668,谢谢!

FAQs

Package last updated on 21 Aug 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc