(supermind量化策略)a1/rsi小于65、归属母公司股东的净利润(同比增长率)大

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

问财量化选股策略逻辑

本选股策略为:RSI指标小于65,归属母公司股东的净利润同比增长率大于20%小于等于100%,集中度(前20股合计占比)小于70%。适合寻找具有成长性、规模适中、分散度高的股票。

选股逻辑分析

在技术面方面,RSI指标小于65,意味着被筛选出的股票都处于相对弱势的状态,有上涨的潜力;在基本面方面,净利润同比增长率大于20%小于等于100%,代表股票的成长性较好,集中度小于70%表示该股票分散度高。通过这些条件的筛选,可以挑选出具有成长性、规模适中、分散度高的股票。

有何风险?

在集中度的筛选方面,选取集中度小于70%的股票,有可能会忽略了某些行业内集中度高但业绩表现优秀的公司。同时,本选股策略忽略了其他基本面和技术面指标,可能会忽略一些优质股票。

如何优化?

可以增加其他基本面和技术面指标来筛选优质股票,如股价与市净率、ROE、市场相对强弱指标等。同时,可以考虑针对不同行业,增加特定的筛选条件和指标,以更好地挖掘优质股票。在集中度的筛选方面,可以将集中度阈值进行量化处理,如选取前30股合计占比小于70%的股票等。

最终的选股逻辑

本选股逻辑为:RSI指标小于65,归属母公司股东的净利润同比增长率大于20%小于等于100%,集中度(前20股合计占比)小于70%。

同花顺指标公式代码参考

//选取最新季度净利润同比增长率大于20%小于等于100%且集中度小于70%的A股股票
SELECT
    S_INFO_WINDCODE AS CODE,
    S_CON_WINDCODE AS NAME,
    S_VAL_MV / POWER(10, 8) AS MV,
    S_DQ_AMT / S_VAL_MV AS concentration_ratio,
    S_VAL_PB_NEW,
    S_VAL_PE_TTM,
    S_VAL_PS_TTM,
    S_FA_EPS_BASIC_EXCL_EXTRA_TTM,
    S_FA_YOYPROFIT_MINORITY,
    S_FA_YOYPROFIT_ISSUE
FROM
    ASHAREDESCRIPTION,
    ASHAREEODDERIVATIVEINDICATOR,
    ASHAREFINANCIALINDICATOR
WHERE
    S_INFO_EXCHMARKET = 'SSE'
        AND S_DQ_TRADESTATUS <> '停牌'
        AND S_INFO_ST_FLAG = '否'
        AND TRADE_DT BETWEEN ADD_MONTHS(TRUNC(TO_DATE(CURRENT_DATE, 'YYYY-MM-DD'), 'YYYY'), -6)
        AND ADD_MONTHS(TRUNC(TO_DATE(CURRENT_DATE, 'YYYY-MM-DD'), 'YYYY'), -3) - 1
        AND S_INFO_LISTEDSTATE <> '退市'
        AND S_INFO_WINDCODE NOT LIKE '%B'
        AND S_INFO_WINDCODE = S_CON_WINDCODE
        AND S_INFO_WINDCODE = S_VAL_WINDCODE
        AND S_VAL_PB_NEW IS NOT NULL
        AND S_VAL_PB_NEW > 0
        AND S_VAL_PE_TTM IS NOT NULL
        AND S_VAL_PS_TTM IS NOT NULL
        AND S_FA_EPS_BASIC_EXCL_EXTRA_TTM IS NOT NULL
        AND S_FA_YOYPROFIT_MINORITY IS NOT NULL
        AND S_FA_YOYPROFIT_ISSUE IS NOT NULL
        AND TRUNC(TRADE_DT, 'Q') =
    (
        SELECT
            max(TRUNC(TRADE_DT, 'Q'))
        FROM
            ASHAREEODDERIVATIVEINDICATOR
        WHERE
            TRADE_DT BETWEEN ADD_MONTHS(TRUNC(TO_DATE(CURRENT_DATE, 'YYYY-MM-DD'), 'YYYY'), -6)
            AND ADD_MONTHS(TRUNC(TO_DATE(CURRENT_DATE, 'YYYY-MM-DD'), 'YYYY'), -3) - 1
    )
        AND S_FA_YOYPROFIT_MINORITY > 0.2
        AND S_FA_YOYPROFIT_MINORITY <= 1
        AND S_DQ_AMT / S_VAL_MV <= 0.7
        AND S_VAL_MV >= 2;

Python代码参考

# 导入需要使用的库
import pandas as pd
import tushare as ts
import talib

# 选股函数
def stock_picking(data):
    # 计算RSI指标
    rsi = talib.RSI(data['close'], timeperiod=14)

    # 筛选规模在2亿以上的A股股票
    stock_list = ts.get_stock_basics().index.tolist()
    market_capitalization = ts.get_stock_basics().loc[stock_list]['totals'] * ts.get_stock_basics().loc[stock_list]['price']
    stock_list = market_capitalization[market_capitalization >= 2e8].index.tolist()

    # 计算归属母公司股东的净利润同比增长率
    data['net_profits_growth'] = data['net_profits'].pct_change()

    # 筛选集中度小于70%的股票
    stock_concentration = data[['amount']].sort_values('amount', ascending=False)
    concentration_ratio = stock_concentration['amount'].iloc[:20].sum() / stock_concentration['amount'].sum()
    filter_cond = (concentration_ratio < 0.7)

    # 筛选满足条件的股票
    filter_cond = filter_cond & (rsi < 65) & (data['net_profits_growth'] > 0.2) & (data['net_profits_growth'] <= 1)

    # 按个股热度从大到小排序
    stock_list = data[filter_cond].groupby(level=0).sum().sort_values('amount', ascending=False).index.tolist()

    return stock_list
    ## 如何进行量化策略实盘?
    请把您优化好的选股语句放入文章最下面模板的选股语句中即可。

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

    模板如何使用?

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


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

评论