import os
from datetime import datetime
from vnpy.trader.tqz_extern.tools.file_path_operator.file_path_operator import TQZFilePathOperator
from vnpy.trader.tqz_extern.tools.pandas_operator.pandas_operator import pandas
from vnpy.app.tqz_hft_parser_app.tqz_constant import TQZLogTitles
class TQZHftParserApp:
# --- api part ---
@classmethod
def tqz_reDump_format_log(cls, source_log_all_path):
"""
Parse source_log_file with all_path to code_csv.
"""
log_dataframe = cls.__get_source_log_dataframe(source_log_all_path=source_log_all_path)
code_parser_fold = f'{cls.__parser_result_fold()}/{"hft_" + datetime.now().strftime("%Y%m%d")}'
if os.path.exists(code_parser_fold) is False:
os.mkdir(code_parser_fold)
[pandas.DataFrame.to_csv(
cls.__get_code_log_dataframe(source_log_all_path=source_log_all_path, code=code),
path_or_buf=f'{code_parser_fold}/{code.replace(".", "_")}.csv',
index=False
) for code in cls.__get_all_codes(log_dataframe)]
# --- private part ---
@classmethod
def __get_source_log_all_path(cls):
"""
Get all_path of source log file.
"""
source_log_filename = "hft_" + datetime.now().strftime("%Y%m%d") + ".log"
source_log_all_path = f'{cls.__source_log_fold()}/{source_log_filename}'
assert os.path.exists(source_log_all_path) is True, f'{source_log_all_path} not exist.'
return source_log_all_path
@classmethod
def __get_source_log_dataframe(cls, source_log_all_path: str):
"""
Get dataframe based on source log with source_log_all_path.
"""
line_log_dictionary_list = []
for line in open(source_log_all_path).readlines():
line_log_dictionary = {}
for line_log_item in line.rstrip().split(" ")[-1].replace('[', '').replace(']', '').split(","):
line_log_dictionary[line_log_item.split(':')[0]] = line_log_item.split(':')[1]
line_log_dictionary_list.append(line_log_dictionary)
return pandas.DataFrame(line_log_dictionary_list)
@classmethod
def __get_code_log_dataframe(cls, source_log_all_path: str, code: str):
"""
Get code dataframe based on source log with source_log_all_path and code_name.
"""
source_log_dataframe = cls.__get_source_log_dataframe(source_log_all_path=source_log_all_path)
return source_log_dataframe.loc[source_log_dataframe[TQZLogTitles.CODE.value]==code]
@staticmethod
def __get_all_codes(source_log_dataframe: pandas.DataFrame) -> list:
"""
Get codes list based on source log.
"""
return list(set(list(source_log_dataframe[TQZLogTitles.CODE.value])))
@staticmethod
def __parser_result_fold():
return f'{TQZFilePathOperator.father_path(source_path=__file__)}/parser_result_fold'
@staticmethod
def __source_log_fold():
return f'{TQZFilePathOperator.father_path(source_path=__file__)}/source_log_fold'
if __name__ == '__main__':
source_log_all_path_test = f'{TQZFilePathOperator.father_path(source_path=__file__)}/source_log_fold/{"hft_" + "20211123" + ".log"}'
TQZHftParserApp.tqz_reDump_format_log(source_log_all_path=source_log_all_path_test)
量化交易之hft篇 - re dump log源文件
原创ErwinSmith 博主文章分类:HFT ©著作权
©著作权归作者所有:来自51CTO博客作者ErwinSmith的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
量化交易开发之基本语法(三)
本教程则是以量化的情景从零讲解python编程,所以将更适合想学做量化策略的人。
数据 变量名 python -
量化交易开发之函数API(四)
我们讲解一下python中的函数知识
API 数据 python -
量化交易开发之初识量化(一)
本系列课程将开启手把手保姆级实战课程,开发属于你自己的量化策略!!!
量化交易 策略因子 实战教学 -
量化交易之hft篇 - alpha因子 (DiffAlpha)
【代码】量化交易之hft篇 - alpha因子 (DiffAlpha)
c++ #include #pragma -
量化交易之hft篇 - alpha因子 (BookAlpha)
【代码】量化交易之hft篇 - alpha因子 (BookAlpha)
c++ #include ios #pragma -
量化交易之HFT篇 - long beach - SigMACD.cc
【代码】量化交易之HFT篇 - long beach - SigMACD.cc。
c++ hft List ide #include -
量化交易之HFT篇 - long beach - SigMACD.h
【代码】量化交易之HFT篇 - long beach - SigMACD.h。
c++ hft #include ide #ifndef -
量化交易之HFT篇 - long beach - SigKalmanFilter.cc
【代码】量化交易之HFT篇 - long beach - SigKalmanFilter.cc。
c++ hft List #include lua -
量化交易之HFT篇 - long beach - SigBook.cc
【代码】量化交易之HFT篇 - long beach - SigBook.cc。
hft #include hg ide -
量化交易之HFT篇 - 高频做市模型源码(.h文件)
"""事先声明, 模型源码仅作参考和交流使用, 不能直接用于实盘"""#prag
c++ #include ide json -
量化交易之HFT篇 - long beach - SigMa.h
【代码】量化交易之HFT篇 - long beach - SigMa.h。
c++ hft #include ide #ifndef -
量化交易之HFT篇 - long beach - SigKalmanFilter.h
【代码】量化交易之HFT篇 - long beach - SigKalmanFilter.h。
hft c++ ide #include #ifndef -
量化交易之HFT篇 - long beach - SigDiff.h
【代码】量化交易之HFT篇 - long beach - SigDiff.h。
hft ide #include #ifndef