(supermind量化策略)a1/rsi小于65、外盘除内盘大于1

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

问财量化选股策略逻辑

选股逻辑包括:RSI小于65,外盘/内盘大于1.3,15分钟周期MACD绿柱变短。

选股逻辑分析

该选股逻辑考虑了技术面和市场流通性,并且结合了短线特征,能够较好地避免市场风险和行业风险等问题。

有何风险?

  1. 选股过于依赖技术面指标,忽略了公司基本面等因素,可能导致选出的股票无法全面反映企业价值;
  2. 股票交易中存在随机波动和交易成本等问题,可能影响选股策略的收益;
  3. MACD指标的短线特征可能不够稳定,可能会出现买入过早或卖出过晚等问题。

如何优化?

  1. 在技术面指标的基础上,加入市场、行业、经济等其他因素,综合考虑企业的价值和风险;
  2. 加强风险管理,避免选股过多或过少,保证整个投资组合的收益率和稳定性;
  3. 细化和优化参数设置,适当扩大时间跨度,加入场内外资金流向等其他因素,优化选股策略的有效性和稳健性。

最终的选股逻辑

选股逻辑包括:RSI小于65,外盘/内盘大于1.3,15分钟周期MACD绿柱变短。

同花顺指标公式代码参考

// RSI指标计算公式
LC := REF(CLOSE,1);
RSI1:=MA(MAX(CLOSE-LC,0),N)/MA(ABS(CLOSE-LC),N)*100;
RSI(N):MA(RSI1,M);

// 外盘/内盘计算公式
UP:=IF(CLOSE>LC,VOL,0);
DOWN:=IF(CLOSE<LC,VOL,0);
OSC:=SUM(UP,14)/SUM(DOWN,14);

// MACD指标计算公式
DIF:=EMA(CLOSE,SHORT)-EMA(CLOSE,LONG);
DEA:=EMA(DIF,M);
MACD:(DIF-DEA)*2;
MACD_BAR:(DIF-DEA)*2, COLORSTICK;

// 完整策略选股公式
SELECT(C,OSC/VOL>1.3 AND RSI(14)<65 AND CROSS(MACD_BAR,REF(MACD_BAR,1)) AND MACD_BAR<REF(MACD_BAR,1),REF(VOL_JJ,1),COLORGREEN);

Python代码参考

import akshare as ak
import pandas as pd
from talib import abstract
from datetime import datetime, timedelta


# 判断股票是否在主升阶段
def is_on_up_trend(daily_data):
    ma240 = daily_data["收盘价"].rolling(240).mean()
    ma120 = daily_data["收盘价"].rolling(120).mean()
    ma60 = daily_data["收盘价"].rolling(60).mean()
    if ma240.iloc[-1] > ma120.iloc[-1] > ma60.iloc[-1] > daily_data.iloc[-1]["收盘价"]:
        return True
    else:
        return False


# 计算MACD指标
def calculate_macd(data):
    talib_macd = abstract.MACD(data)
    macd = pd.DataFrame({"DIF": talib_macd[0], "DEA": talib_macd[1], "MACD": talib_macd[2] * 2})
    macd_bar = pd.Series(talib_macd[2] - talib_macd[1]) * 2
    return macd, macd_bar


# 获取当前A股股票列表
stock_list = ak.stock_zh_a_spot_em()

# 计算并筛选符合条件的股票
selected_stocks = []
for stock_code in stock_list.index:
    # 获取股票数据
    daily_data = ak.stock_zh_a_daily_em(stock_code, adjust="hfq")
    if daily_data is None:
        continue
    rsi_data = ak.stock_zh_index_daily_indicator(stock_code)
    if rsi_data is None:
        continue
    rsi_14 = rsi_data.iloc[-1]["rsi_14"]
    if rsi_14 >= 65:
        continue
    inner_volume = ((daily_data["收盘价"].values - daily_data["最低价"].values) - (daily_data["最高价"].values - daily_data["收盘价"].values)) / (daily_data["最高价"].values - daily_data["最低价"].values) * daily_data["成交量"].values
    outer_volume = daily_data["成交量"].values - inner_volume
    outer_inner_ratio = outer_volume[-1] / inner_volume[-1]
    if outer_inner_ratio <= 1.3:
        continue
    if not is_on_up_trend(daily_data):
        continue
    if daily_data.iloc[-1]["是否ST"] != "否":
        continue
    if daily_data.iloc[-1]["是否退市"] != "否":
        continue
    # 计算MACD并判断是否绿柱变短
    datetime_now = datetime.now()
    time_str = (datetime_now - timedelta(days=1)).strftime("%Y-%m-%d") + " 15:00:00"
    data = ak.stock_zh_a_minute_em(stock_code, start_date=time_str, end_date=datetime_now.strftime("%Y-%m-%d %H:%M:%S"), adjust="hfq")
    if data is None or len(data) < 2:
        continue
    macd, macd_bar = calculate_macd(data)
    if macd_bar.iloc[-1] >= macd_bar.iloc[-2]:
        continue
    selected_stocks.append(stock_code)

# 输出符合条件的股票代码和名称
for stock_code in selected_stocks:
    stock_info = stock_list.loc[stock_code]
    if stock_info["名称"] == "None":
        continue
    print(f"{stock_code}、{stock_info['名称']}")
    ## 如何进行量化策略实盘?
    请把您优化好的选股语句放入文章最下面模板的选股语句中即可。

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

    模板如何使用?

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


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

评论