1、支持任意周期K线。

2、支持K线偏移。

3、支持指数、主力。

4、支持文华商品指数。

默认支持的是:5秒、1分钟、3分钟、5分钟、日线。

时间:2010年到现在。

数据如下:

5秒线,大宗商品指数(文华商品7186)

5秒线,工业品

1分钟,螺纹钢指数

5分钟前偏移60秒,大宗商品指数,时间去除了‘:’。

代码比较复杂,贴上导出的库:

/*
libkline特性
1、支持任意周期K线。K线周期以秒为单位,大于总交易时间的都认为是日线。整个交易日期间不会因为
暂时停盘截断K线,例如:rb的交易时间是晚上21:00:00-23:00:00,白天9:00:00-10:15:00...
如果周期是7分钟(即420秒),对应的K线是21:07:00、21:14:00、...22:59:00、9:06:00、..
22:59:00-23:00:00的数据算到9:06:00那根K线上。
2、支持K线偏移。偏移量以秒为单位,支持正负值。同样以rb合约,7分钟周期为例。假如希望K线滞后
1分钟(即60秒),则偏移量为正数60,对应的K线是21:08:00、21:15:00、...23:00:00、
9:07:00、...。假如希望K线提前1分钟(即60秒),则偏移量为负数-60,对应K线是21:06:00、
21:13:00、...22:58:00、9:05:00、...。K线提前可能导致K线增多一根(最后)的情况。
3、K线自动补全。同样以rb合约,1分钟周期为例。如果第一个tick是21:01:01(该tick
应该是21:02:00这根K线),则按最新价补上21:01:00这根K线。如果相邻两个tick时间分别是
21:03:18和21:06:02,则会以21:03:18的数据补上21:05:00、21:06:00两根K线。
4、集合竞价凑入下个区间。例如:20:59:00的数据认为是21:00:00,8:59:00的数据认为是
9:00:00,只有夜盘和白盘开始前5分钟的数据才认为是集合竞价数据。
*/ #ifndef LIB_KLINE_H
#define LIB_KLINE_H #ifdef LIBKLINE_EXPORTS
#define LIBKLINE_API __declspec(dllexport)
#else
#define LIBKLINE_API
#endif #include "ThostFtdcUserApiStruct.h"
#include "user_define_struct.h"
#include <functional>
#include <string>
#include <vector>
#include <list> #define COMMODITY_EXCHANGE "DZSPZS" //类别:大宗商品指数 typedef std::function<void(const SoffsetKline&,std::list<Skline>*)> lpGetKline;
typedef std::function<void(const char*,CThostFtdcDepthMarketDataField*)> lpGetIndex;
typedef std::function<void(const CThostFtdcDepthMarketDataField*)> lpGetShot;
typedef std::function<void(const SoffsetKline&, std::list<Skline>*)> lpTrig;
typedef std::function<void(const char*, std::list<CThostFtdcDepthMarketDataField>*)> lpGetIndexTick;
typedef std::function<void(const char*, double, CThostFtdcDepthMarketDataField*)> lpCommodityInfo;
typedef std::function<void(const char*)> lpErrMsg; class LIBKLINE_API libkline
{
public:
libkline();
~libkline(); //重置内部数据
void Reset(lpErrMsg lp = nullptr);
//错误信息回调
void SetErrMsg(lpErrMsg lp = nullptr); ///共有属性及回调
//设置交易日
void SetTradingDay(const char* pTradingDay, const char* pPreTradingDay); //设置K线周期
void SetCycle(std::vector<int> vecCycle); //启用K线偏移
//bHold:是否独占周期 true则该品种SetCycle置入的周期不起作用
void SetOffsetCycle(const SoffsetKline& ok, bool bHold); //K线更新触发
void SetUpdateTrig(const SoffsetKline& ok, lpTrig p); //K线生成触发
void SetNewTrig(const SoffsetKline& ok, lpTrig p); //设置K线,覆盖式
void SetKline(const SoffsetKline& ok, std::list<Skline>& listKline); //处理历史数据
//大宗商品指数需要依赖基本指数,一旦启用则缓存排序后再处理
void SetDealHistoryData(bool b); //是否处理完前tick
bool IsDealPreTick(); //是否在运行
bool IsRunning(); ///多商品指数
//需要订阅组成品种的所有可交易合约
void SetCommodity(const char* name, const char* abbreviation, int nMultiply, std::vector<SinstrumentProperty>& vec); //设置初始价格
void SetOriginalPrice(const char* abbreviation, const char* pCode, CThostFtdcDepthMarketDataField& last_data, double dPrice); //获取商品指数的乘数 0:代表未找到该品种
int GetCommodityMultiply(const char* abbreviation); //获取新增的指数的初始价格
void GetCommodityInfo(lpCommodityInfo lp); ///单商品
//添加合约属性
void AddVariety(const SinstrumentProperty* p); //设置指数表
bool SetIndexTable(const char* pProductID, CThostFtdcDepthMarketDataField& field); //设置主力
bool SetMainCode(const char* pProductID, const char* pMainCode); //压入实时tick数据
void PushTick(CThostFtdcDepthMarketDataField* pData); //运行
void Run(); //强行停止,缓存的数据都不处理了,立刻退出
void ForceStop(); //安全停止,将缓存的数据都处理完毕,在退出
void SafeStop(); //释放资源
void Release(); //获取K线
//bAll:是否请求所有,如果true,则pInstrumentID和nCycle失效
void GetKline(lpGetKline lp, SoffsetKline* p, bool bAll = false); //获取指数表
//pProductID:rb 空则返回所有
void GetIndex(lpGetIndex lp, const char* pProductID = nullptr); //获取快照
//pExchangeID:SHFE 空则返回所有
void GetShot(lpGetShot lp, const char* pExchangeID = nullptr); //获取指数tick
void GetIndexTick(lpGetIndexTick lp, const char* pInstrumentID = nullptr); //收缩偏移K线
void ShrinkOffsetKline(const SoffsetKline& ok, std::list<Skline>& targetKline,
int nThisCycle, std::list<Skline>& thisKline); //校验偏移k线的最后日期时间
void VerifyOffsetKline(const SoffsetKline& ok, Skline& lastKline); protected:
void* pObj;
}; #endif//LIB_KLINE_H

x64下载链接(debug|release及各版本vs通用):https://files.cnblogs.com/files/rmdmn/libkline.rar

k线生成模块的更多相关文章

  1. 使用Python的pandas模块、mplfinance模块、matplotlib模块绘制K线图

    目录 pandas模块.mplfinance模块和matplotlib模块介绍 pandas模块 mplfinance模块和matplotlib模块 安装mplfinance模块.pandas模块和m ...

  2. Highstock生成股票K线图

    在线演示 本地下载 使用HightStock生成股票K线图例子.

  3. PHP使用HighChart生成股票K线图详解

    本人qq群也有许多的技术文档,希望可以为你提供一些帮助(非技术的勿加). QQ群:   281442983 (点击链接加入群:http://jq.qq.com/?_wv=1027&k=29Lo ...

  4. k线、指标绘制

    我接触的绘制有两种:gdi+和qt绘图.可以灵活的绘制任何想要的东西. 先上效果图吧. 如下:基于gdi+的股指和股票的绘制.上面是沪深成分股实时生成的股票指数走势,下面是IF主力走势和开平仓位置. ...

  5. IDEA Plugin,写一个看股票指数和K线的插件

    作者:小傅哥 博客:https://bugstack.cn 沉淀.分享.成长,让自己和他人都能有所收获! 一.前言 没招了,不写点刺激的,你总是不好好看! 以前,我不懂.写的技术就是技术内容,写的场景 ...

  6. C#下如何用NPlot绘制期货股票K线图(3):设计要显示的股票价格图表窗口并定义相应类的成员及函数

    [内容简介] 上一篇介绍了要显示K线图所需要的数据结构,及要动态显示K线图,需要动态读取数据文件必需的几个功能函数.本篇介绍要显示蜡烛图所用到的窗口界面设计及对应类定义.下面分述如下: [窗口界面] ...

  7. 利用JFreeChart绘制股票K线图完整解决方案

    http://blog.sina.com.cn/s/blog_4ad042e50100q7d9.html 利用JFreeChart绘制股票K线图完整解决方案 (2011-04-30 13:27:17) ...

  8. c#版 K线控件(Stock)

    K线起源于日本米市交易,它的基本用途就是为了寻找"买卖点".股市及期货市场中的K线图的画法包含四个数据,即开盘价.最高价.最低价.收盘价,所有的k线都是围绕这四个数据展开,反映大势 ...

  9. 金融量化分析【day111】:Matplotib-绘制K线图

    一.绘制k线图 1.使用金融包出错解决 1.错误代码 ImportError: No module named finance 2.解决办法 https://github.com/matplotlib ...

随机推荐

  1. formateDate

    function formateDate(fmt, date) { let _this = new Date(date) let o = { "M+": _this.getMont ...

  2. 修改sudoers

    使用visudo命令 [root@898f990a8808 etc]# visudo

  3. gdck01

    有好几年 好几年 好几年 我成天在抱怨 我没钱 我没钱 恨老天不开眼 不开眼 不开眼 为什么好的事 都跟我没有缘

  4. Java教程-修炼

    在2020这个特殊的时期,在家就是为国家做贡献!一切都会好起来的,加油中国!! Java 第一章 Java概述 1.1 Java历史 1.2 Java语言最主要的特点 1.3 Java环境搭建 1.3 ...

  5. web攻击与防御

    攻击方式 利用输出值转义漏洞 跨站脚本攻击(XSS) SQL注入攻击 OS命令注入攻击 HTTP首部注入攻击 邮件首部注入攻击 文件目录遍历攻击 利用设置或设计缺陷 强制游览 开放重定向 不正确的错误 ...

  6. HTML5创建高德地图

    创建高德地图 功能真的很好很强大,有图有证据! 1.申请key值 去官网2.https://webapi.amap.com/maps?v=1.4.11&key=e22196035aaa10db ...

  7. CodeForces - 1105D 多源搜索

    #include<bits/stdc++.h> using namespace std; typedef long long ll; struct node{ int x,y; ll se ...

  8. PTA 1002 A+B for Polynomials

    问题描述: This time, you are supposed to find A+B where A and B are two polynomials. Input Specification ...

  9. Codeforces Round #622 (Div. 2).C2 - Skyscrapers (hard version)

    第二次写题解,请多多指教! http://codeforces.com/contest/1313/problem/C2 题目链接 不同于简单版本的暴力法,这个数据范围扩充到了五十万.所以考虑用单调栈的 ...

  10. 中文 json_encode之后字符长度问题

    问题描述: 将某个字符串$str 进行json编码,即json_encode($str)后变成Unicode字符存入数据库,会发现中文的长度明明没有超过设置的字符长度最大值,但是却抛出字段长度过长错误 ...