溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Python量化因子測算與繪圖的代碼怎么寫

發(fā)布時間:2023-02-24 11:02:37 來源:億速云 閱讀:124 作者:iii 欄目:開發(fā)技術(shù)

這篇“Python量化因子測算與繪圖的代碼怎么寫”文章的知識點大部分人都不太理解,所以小編給大家總結(jié)了以下內(nèi)容,內(nèi)容詳細,步驟清晰,具有一定的借鑒價值,希望大家閱讀完這篇文章能有所收獲,下面我們一起來看看這篇“Python量化因子測算與繪圖的代碼怎么寫”文章吧。

量化因子的測算通常都是模擬交易,計算各種指標(biāo),其中:

  • 測算需要用到的第三方庫:numpy,pandas,talib

  • 繪圖需要用到的第三方庫:matplotlib,seaborn

其他庫隨策略的需要額外添加

因子測算框架

這里博主分享自己測算時常使用的流程,希望與大家共同進步!

測算時從因子到收益的整個流程如下:策略(因子組合) -> 買賣信號 -> 買點與賣點 -> 收益

因此我們在測算時,針對每一個個股:

1. 預(yù)處理股票數(shù)據(jù)

首先這里是常用的一個工具導(dǎo)入,包括測算用的庫與繪圖用的庫(含圖片中文顯示空白解決方案)

# 測算用
import numpy as np
import pandas as pd
from copy import deepcopy
from tqdm import tqdm
from datetime import datetime
import talib
# 繪圖用
import matplotlib as mpl
import matplotlib.pyplot as plt
import seaborn as sns
%matplotlib inline
# 繪圖現(xiàn)實中文
sns.set()
plt.rcParams["figure.figsize"] = (20,10)
plt.rcParams['font.sans-serif'] = ['Arial Unicode MS']  # 當(dāng)前字體支持中文
plt.rcParams['axes.unicode_minus'] = False  # 解決保存圖像是負號'-'顯示為方塊的問題
# 其他
import warnings
warnings.filterwarnings("ignore")

然后是循環(huán)讀取股票的代碼:

import os
def readfile(path, limit=None):
    files = os.listdir(path)
    file_list = []
    for file in files:  # 遍歷文件夾
        if not os.path.isdir(file):
            file_list.append(path + '/' + file)
    if limit:
        return file_list[:limit]
    return file_list
stock_dict = {}
for _file in tqdm(readfile("../data/stock_data")):
    if not _file.endswith(".pkl"):
        continue
    # TODO 這里可以添加篩選,是否需要將當(dāng)前的股票添加到測算的股票池中
    file_df = pd.read_pickle(_file)
    file_df.set_index(["日期"], inplace=True)
    file_df.index.name = ""
    file_df.index = pd.to_datetime(file_df.index)
    file_df.rename(columns={'開盤':'open',"收盤":"close","最高":"high","最低":"low","成交量":"volume"},inplace=True)
    stock_code = _file.split("/")[-1].replace(".pkl", '')
    # TODO 這里可以添加日期,用來截取一部分數(shù)據(jù)
    stock_dict[stock_code] = file_df

上面一部分是處理股票數(shù)據(jù),處理后的數(shù)據(jù)都會保存在 stock_dict 這個變量中,鍵是股票的代碼,值是股票數(shù)據(jù)

2. 指標(biāo)測算

測算指標(biāo)時,我們以一只股票為例:

for _index,_stock_df in tqdm(stock_dict.items()):
    measure_df = deepcopy(_stock_df)

代碼中的:

  • 這里的measure_df即要測算的dataframe數(shù)據(jù)

  • 使用deepcopy是防止測算的過程影響到原始數(shù)據(jù)

然后我們就可以循環(huán)這一個股票的每一行(代表每一天),測算的交易規(guī)則如下:

  • 買入規(guī)則:買入信號發(fā)出&當(dāng)前沒有持倉,則買入

  • 賣出規(guī)則:賣出信號發(fā)出&當(dāng)前有持倉,則賣出

# 開始測算
trade_record_list = []
this_trade:dict = None
for _mea_i, _mea_series in measure_df.iterrows(): # 循環(huán)每一天
    if 發(fā)出買入信號:
        if this_trade is None:  # 當(dāng)前沒有持倉,則買入
            this_trade = {
                "buy_date": _mea_i,
                "close_record": [_mea_series['close']],
            }
    elif 發(fā)出賣出信號:
        if this_trade is not None:  # 要執(zhí)行賣出
            this_trade['sell_date'] = _mea_i
            this_trade['close_record'].append(_mea_series['close'])
            trade_record_list.append(this_trade)
            this_trade = None
    else:
        if this_trade is not None:  # 當(dāng)前有持倉
            this_trade['close_record'].append(_mea_series['close'])

上述代碼中,我們將每一個完整的交易(買->持有->賣),都保存在了trade_record_list變量中,每一個完整的交易都會記錄:

{
    'buy_date': Timestamp('2015-08-31 00:00:00'), # 買入時間
    'close_record': [41.1,42.0,40.15,40.65,36.6,32.97], # 收盤價的記錄
    'sell_date': Timestamp('2015-10-12 00:00:00')} # 賣出時間
    # TODO 也可以添加自定義記錄的指標(biāo)
}

3. 測算結(jié)果整理

直接使用 pd.DataFrame(trade_record_list),就可以看到總的交易結(jié)果:

Python量化因子測算與繪圖的代碼怎么寫

整理的過程也相對簡單且獨立,就是循環(huán)這個交易,然后計算想要的指標(biāo),比如單次交易的年化收益可以使用:

trade_record_df = pd.DataFrame(trade_record_list)
for _,_trade_series in trade_record_df.iterrows():
    trade_record_df.loc[_i,'年化收益率'] = (_trade_series['close_record'][-1] - _trade_series['close_record'][0])/_trade_series['close_record'][0]/(_trade_series['sell_date'] - _trade_series['buy_date']).days * 365 # 年化收益
    # TODO 這里根據(jù)自己想要的結(jié)果添加更多的測算指標(biāo)

4. 結(jié)果繪圖

繪圖的代碼通常比較固定,比如勝率圖:

# 清理繪圖緩存
plt.cla()
plt.clf()
# 開始繪圖
plt.figure(figsize=(10, 14), dpi=100)
# 使用seaborn繪制勝率圖
fig = sns.heatmap(pd.DataFrame(total_measure_record).T.round(2), annot=True, cmap="RdBu_r",center=0.5)
plt.title("勝率圖")
scatter_fig = fig.get_figure()
# 保存到本地
scatter_fig.savefig("勝率圖")
scatter_fig.show() # 最后顯示

以上就是關(guān)于“Python量化因子測算與繪圖的代碼怎么寫”這篇文章的內(nèi)容,相信大家都有了一定的了解,希望小編分享的內(nèi)容對大家有幫助,若想了解更多相關(guān)的知識內(nèi)容,請關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI