FutuQuant量化接口Nodejs版本
基于 FutuQuant v3.2 底层协议封装的nodejs版本接口,数据格式使用 protobuf,使用前请先在本地或者服务端启动 FutuOpenD 服务。
相关说明:
为了方便使用,请注意部分接口参数及返回结果和富途官方版本不完全一致,详细请参考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
使用
const FtQuant = require('./src/futuquant');
const fs = require('fs');
const path = require('path');
const bunyan = require('bunyan');
const bunyanDebugStream = require('bunyan-debug-stream');
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];
const bunyanLogger = bunyan.createLogger({
name: 'sys',
streams: [{
level: 'debug',
type: 'raw',
serializers: bunyanDebugStream.serializers,
stream: bunyanDebugStream({ forceColor: true }),
}],
});
const ft = new FtQuant({
ip: '127.0.0.1',
port: 11111,
userID,
}, bunyanLogger);
const init = async () => {
let res = null;
res = await ft.initConnect();
console.log('initConnect', res);
res = await ft.getGlobalState();
console.log('getGlobalState', res);
await ft.trdUnlockTrade(true, pwdMd5);
const { accID } = (await ft.trdGetAccList())[0];
await ft.setCommonTradeHeader(1, accID, 1);
};
init();
测试
请先修改test/futuquant.test.js
中FutuOpenDXMLPath
的路径,然后执行npm install
或yarn
安装相关依赖。
运行测试:
npm test
广告
如有需要,请填写推荐人牛牛号:5894668,谢谢!