(supermind量化)连续3天以上大单净量大于0

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

问财量化选股策略逻辑

选股逻辑:在 MACD 指标零轴以上的基础上,结合涨跌幅×超大单净量和连续3天以上大单净量大于0.05的条件,选取符合要求的股票。

选股逻辑作为第一个段落放入标题为 ## 问财量化选股策略逻辑 的段落中。分析以上的选股逻辑(每个逻辑以 "," 进行分隔),分析选股的逻辑(放入标题为 ## 选股逻辑分析 的段落),有什么风险?(放入标题为 ## 有何风险? 的段落)如何优化?(放入标题为 ## 如何优化? 的段落)并最终给出完善选股逻辑(放入标题为 ## 最终的选股逻辑 的段落),请用 Markdown 格式。

选股逻辑分析

与上一个选股逻辑相似,该选股策略也是通过 MACD 指标、涨跌幅×超大单净量等指标来筛选股票。但同时,还引入了连续3天以上大单净量大于0.05的条件,意味着该策略更加严格和注重成交量的稳定性。该策略同样适用于短期投机型交易。

有何风险?

以下是该选股策略可能面临的风险:

  1. 忽略了股票基本面因素,过度依赖技术分析和交易量指标;
  2. 连续三天的大单净量指标并不能完全反应机构投资者的真实操作;
  3. 涨跌幅×超大单净量指标分析起来较为复杂,容易出现误判。

如何优化?

以下是该选股策略的优化建议:

  1. 加入更多股票基本面指标,例如市盈率、净资产收益率、财务健康度等,提升投资决策的准确性;
  2. 逐步引入更多量化指标,例如MACD柱状图、KDJ指标等,综合分析多重因素;
  3. 注意调整选股时间跨度和条件,避免策略过于短期和偏颇。

最终的选股逻辑

选股策略:MACD指标零轴以上、涨跌幅×超大单净量以及连续3天以上大单净量大于0.05的条件进行投资决策。

同花顺指标公式代码参考

以下是 MACD 指标的通达信指标公式:

短期指数平滑移动平均线(SHORT):EMA(CLOSE,SHORT);
长期指数平滑移动平均线(LONG):EMA(CLOSE,LONG);
选定周期内平滑异同平均线(DIF):EMA(CLOSE,SHORT)-EMA(CLOSE,LONG);
平滑异同平均线(DEA):EMA(DIF,MID);
MACD柱状图:(DIF-DEA)*2,COLORSTICK;

以下是涨跌幅×超大单净量的通达信指标公式:

涨跌幅(P_CHANGE):(CLOSE-CLOSE[N])/CLOSE[N]100;
大单净量(DDN):((VOL/10000)ABS(CLOSE-REF(CLOSE,1)>=30000(HIGH-LOW)/AMOUNT,20))/AMOUNT
100;

其中,N为选定的时间周期,REF为上一个交易日的收盘价,VOL为成交量,CLOSE为收盘价。

以下是大单净量连续3天以上的通达信指标公式:

DDN3BOLL:MA((DDN>0.05),3);
BUY3:DDN3BOLL>STD(DDN3BOLL,20);
SELL3:DDN3BOLL<(SMA(DDN3BOLL,50)-1*STD(DDN3BOLL,50));

其中,DDN>0.05表示大单净量大于0.05,DDN3BOLL表示DDN连续3天以上满足条件的情况,BUY3表示做多信号,SELL3表示做空信号。

Python代码参考

以下是获取满足选股条件的股票列表的Python代码:

import tushare as ts
import pandas as pd
import talib as ta

# 设置tushare pro的token
token = 'your_token_here'
ts.set_token(token)

# 初始化tushare pro接口
pro = ts.pro_api()

# 获取股票代码
stock_codes = pro.stock_basic(exchange='', list_status='L', fields='ts_code,symbol,name,area,industry,list_date')

# 获取符合选股条件的股票列表
result = []
for code in stock_codes['ts_code']:
    # 获取MACD指标
    df_macd = pro.daily(ts_code=code, start_date='20210801', end_date='20210831')
    dif = ta.EMA(df_macd['close'].values, 12) - ta.EMA(df_macd['close'].values, 26)
    dea = ta.EMA(dif, 9)
    macd = (dif - dea) * 2

    # 获取涨跌幅×超大单净量
    df_vol = pro.moneyflow(ts_code=code, start_date='20210801', end_date='20210831')
    p_change = (df_vol['close'] - df_vol['close'].shift()) / df_vol['close'].shift() * 100
    big_vol = ((df_vol['vol'] / 10000) >= 100) * df_vol['vol'] * ((df_vol['close'] - df_vol['pre_close']) / df_vol['close']) * 100

    # 获取大单净量
    df_ddn = pro.moneyflow(ts_code=code, start_date='20210801', end_date='20210831')
    ddn = ((df_ddn['vol'] / 10000) * abs(df_ddn['close'] - df_ddn['close'].shift()) >= 30000 * (df_ddn['high'] - df_ddn['low']) / df_ddn['amount']) / df_ddn['amount'] * 100

    # 获取连续3天大单净量大于0.05
    ddn3boll = ta.MA(ddn > 0.05, 3)
    buy3 = ddn3boll > ta.STDDEV(ddn3boll, 20)
    sell3 = ddn3boll < (ta.SMA(ddn3boll, 50) - 1 * ta.STDDEV(ddn3boll, 50))

    # 判断是否符合条件
    if macd[-1] > 0 and p_change[-1] > 0 and big_vol[-1] > 0 and buy3[-1] and all(buy3[-3:]):
        result.append(code)
        
print(result)

注:该代码仅供参考,真实情况中需要根据自己的需要进行调整。

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

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

    模板如何使用?

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


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

评论