(iwencai量化策略)竞价涨幅>-2<5_、周线macd在零轴之上、rsi小于65

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

问财量化选股策略逻辑

选股逻辑:选择RSI小于65、周线MACD在零轴之上、竞价涨幅在-2%到5%之间的股票。

选股逻辑分析

该选股策略结合了技术分析和基本面数据分析,选取在RSI小于65、周线MACD在零轴之上的基础上,筛选竞价涨幅在-2%到5%之间的股票,选择具备市场潜力和技术走势的股票。通过运用多重指标和数据,进行综合分析和评估,选出符合条件的股票,达到技术分析和基本面分析的双重目的。

有何风险?

该选股策略存在竞价涨幅波动的风险,可能会出现误判股票市场趋势和技术走势的情况。同时,基本面数据的变化、市场环境和行业政策的动态变化,也会影响该选股策略的准确性和稳定性。

如何优化?

在原选股策略基础上,加入更多技术指标和基本面数据,如动态市盈率、市净率、资产负债率等,并综合考虑其他技术指标和基本面数据,通过综合分析和评估,提高股票选取的准确性和市场价值。同时,结合行业特点和市场趋势,根据股票流通市值和市盈率等因素,动态调整筛选条件,优化选股策略的适应性和灵活性。

最终的选股逻辑

在RSI小于65、周线MACD在零轴之上、竞价涨幅在-2%到5%之间的基础上,结合动态市盈率、市净率、资产负债率等其他技术指标和基本面数据,并根据股票流通市值和市盈率等因素,动态调整筛选条件,选择具备市场潜力和技术走势的股票。通过运用多重指标和数据,进行综合分析和评估,选出符合条件的股票,达到技术分析和基本面分析的双重目的。

同花顺指标公式代码参考

C2: MACD() > 0 AND DEA() > DEA(1)
C3: J2-RANKING < 50 AND J2-RANKING > -20
SELECT * FROM (
SELECT STOCK_LIST.*,
(J2-CLOSE)/CLOSE*100 AS JJZF,
GET_RANKING() AS RANKING 
FROM STOCK_LIST) RESULT
WHERE C1 AND C2 AND C3
ORDER BY RANKING ASC

python代码参考

import pandas as pd
import akshare as ak

def get_ranking(df):
    df = df[df['MACD'] > 0]
    df = df[df['DEA'] > df['DEA'].shift(1)]
    df = df[df['RSI'] < 65]
    df['J2_DIFF'] = df['J2'] - df['CLOSE']
    df['JJZF'] = df['J2_DIFF'] / df['CLOSE'] * 100
    df = df[(df['JJZF'] > -2) & (df['JJZF'] < 5)]
    df = df[(df['流通市值'] >= 50) & (df['流通市值'] <= 100)]
    df['RANKING'] = df['市值'].rank(ascending=False)
    df = df[df['RANKING'] <= 10]
    df.sort_values(by='RANKING', ascending=True, inplace=True)
    return df

def get_stock_list():
    stock_list = ak.stock_zh_a_spot_em()
    stock_list['市值'] = stock_list['市值'].astype(float)
    stock_list['流通市值'] = stock_list['流通市值'].astype(float)
    stock_list = stock_list[stock_list['市值'] > 0]
    stock_list = pd.merge(stock_list, ak.stock_zh_a_tick_tx(symbol="sz000001"), on=['代码'])
    stock_list = pd.merge(stock_list, ak.stock_zh_a_spot_top_n_big_order(symbol="", n='50'), on=['代码'])
    stock_list = pd.merge(stock_list, ak.stock_zh_a_spot_check(symbol="sh600000"), on=['代码'])
    stock_list = pd.merge(stock_list, ak.stock_zh_a_spot_em_limit_up(), on=['代码'])
    stock_list.rename(columns={'当前价': '当前价格', '归属母公司股东的净利润同比增长率(%)': 'NPARENT_NETPROFITYOY', '开盘价': '开盘', '收盘价': '收盘', '最高价': '最高', '最低价': '最低', '日期': '日期', '成交量': '成交量',
                               '成交额': '成交金额', '涨跌幅': '涨跌幅', '总市值': '市值', '前收盘价': '昨收盘', '换手率': '换手率', '板块': '板块', '超大单净量': '超大单净量', 'CURRENT': '当前价格', 'KDJ_K': 'KDJ_K', 'KDJ_D': 'KDJ_D', 'KDJ_J': 'KDJ_J', 'RSI': 'RSI', 'DIFF': 'DIFF', 'DEA': 'DEA', 'MACD': 'MACD', 'SIGNAL': 'SIGNAL', 'BOARD': 'BOARD_CODE', '流通市值': '流通市值'}, inplace=True)
    df = stock_list[['代码', '名称', '日期', '开盘', '收盘', '最高', '最低', '成交量', '成交金额', '涨跌幅', '市值', '流通市值', 'NPARENT_NETPROFITYOY', 'KDJ_K', 'KDJ_D', 'KDJ_J', 'RSI', 'DIFF', 'DEA', 'MACD', 'SIGNAL', '当前价格', '买一量', '卖一量', '板块', 'BOARD_CODE']]
    df.set_index('日期', inplace=True)
    df.sort_values(by=['代码', '日期'], ascending=[True, True], inplace=True)
    df_short = pd.DataFrame()
    for code in df.index.get_level_values('代码').unique():
        temp_df = df[df.index.get_level_values('代码') == code]
        if len(temp_df) > 1:
            res_df = temp_df[['代码', '名称', '日期', '开盘', '收盘', '最高', '最低', '成交量', '成交金额', '涨跌幅', '市值', '流通市值', 'NPARENT_NETPROFITYOY', 'KDJ_K', 'KDJ_D', 'KDJ_J', 'RSI', 'DIFF', 'DEA', 'MACD', 'SIGNAL', '当前价格', '买一量', '卖一量', '板块', 'BOARD_CODE']]
            res_df = res_df[-8:]
            df_short = pd.concat([df_short, res_df])
    stock_list = pd.merge(stock_list, df_short, on=['代码', '名称', '日期', '开盘', '收盘', '最高', '最低', '成交量', '成交金额', '涨跌幅', '市值', '流通市值', 'NPARENT_NETPROFITYOY', 'KDJ_K', 'KDJ_D', 'KDJ_J', 'RSI', 'DIFF', 'DEA', 'MACD', 'SIGNAL', '当前价格', '买一量', '卖一量', '板块', 'BOARD_CODE'])
    stock_list = get_ranking(stock_list)
    return stock_list
    ## 如何进行量化策略实盘?
    请把您优化好的选股语句放入文章最下面模板的选股语句中即可。

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

    模板如何使用?

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


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

评论