需要帮助?

试试AI小助手吧

(supermind量化策略)task17/a/换手率3%-12%、外盘除内盘大于1

用户头像神盾局量子研究部
2023-08-30 发布

问财量化选股策略逻辑

选股逻辑:在换手率3%到12%、外盘/内盘比例大于1.3、昨日9:15匹配价跌停的股票中,按今日竞价金额排序,选取排名前5的股票。

选股逻辑分析

该选股逻辑结合了换手率、外盘/内盘比例和昨日匹配价跌停等多个技术指标,用今日竞价金额来筛选排名前5的股票,增加获利机会。

有何风险?

虽然该选股策略结合了多重技术指标,但仍然存在一定的局限性,无法完全预测市场表现和有关政策对股市的影响等因素,存在选股结果不准确的风险。

如何优化?

可以在该选股逻辑中进一步加入更多的基本面和行业特征等因素,以及对昨日匹配价跌停进行限定,同时应加强研究和分析市场走势和政策变化等因素,提高选股策略的可靠性和波动性等。

最终的选股逻辑

选取换手率3%到12%、外盘/内盘比例大于1.3、昨日9:15匹配价跌停的股票中,按今日竞价金额排序,选取排名前5的股票,并在此基础上加入更多的基本面和行业特征等因素,以及对昨日匹配价跌停进行限定,以提高选股策略的准确性和可靠性。

同花顺指标公式代码参考

以下是同花顺指标所需公式:

选股公式:
SELECT 
	code 
FROM 
	(SELECT 
		code, 
		outvolume / involume AS volume_ratio, 
		turnoverrate, 
		IF(ABS((match-DELAY(close,1))/DELAY(close,1))*100>9.8,1,0) AS pd, 
		close * volume AS turnover, 
		row_number() OVER (ORDER BY close * volume DESC) AS rn 
	FROM 
		KDATA 
	WHERE 
		turnoverrate >= 3 AND turnoverrate <= 12 
		AND outvolume / involume > 1.3) t 
WHERE 
	rn <= 5 AND pd = 1

Python代码参考

import pandas as pd 
from typing import List

def select_stock(data: pd.DataFrame, n: int) -> List[str]:
    selected_stocks = []
    for code, df in data.groupby(level=0):
        match_price = df['match'].iloc[-2]
        if ((df['turnoverrate'].iloc[-1] > 3) and \
            (df['turnoverrate'].iloc[-1] < 12) and \
            (df['outvolume'].iloc[-1] / df['involume'].iloc[-1] > 1.3) and \
            (abs((match_price - df['close'].iloc[-1]) / match_price) > 0.098)):
            selected_stocks.append(code)
    df = data.loc[selected_stocks, ['close','volume']]
    turnover = df['close'] * df['volume']
    df['turnover'] = turnover
    volumes = df['turnover'].sort_values(ascending=False)[:n]
    selected_stocks = list(volumes.index)
    return selected_stocks
    ## 如何进行量化策略实盘?
    请把您优化好的选股语句放入文章最下面模板的选股语句中即可。

    select_sentence = '市值小于100亿' #选股语句。

    模板如何使用?

    点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。


    ## 如果有任何问题请添加 下方的二维码进群提问。
    ![94c5cde12014f99e262a302741275d05.png](http://u.thsi.cn/imgsrc/pefile/94c5cde12014f99e262a302741275d05.png)
收益&风险
源码

评论