(supermind)振幅大于1、股价为18

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

问财量化选股策略逻辑

选股逻辑为:振幅大于1、股价为18.5元、KDJ随机指标(K)增长值。选股策略主要考虑了股票价格波动性、价格合理性以及技术指标的变化。

选股逻辑分析

该选股策略以振幅大于1、股价为18.5元、KDJ随机指标(K)增长值为选股依据。振幅大于1反映了股票价格波动比较大,股价为18.5元则反映了股票价格的合理性,KDJ随机指标(K)增长值反映了股票技术指标的变化趋势。

有何风险?

该选股策略仅考虑了技术指标的变化,没有综合考虑股票的基本面因素,例如财务数据、行业情况等因素。此外,选股策略逻辑过于简单,可能会选到一些潜在风险较大的企业。KDJ随机指标(K)增长值在短时间内增长也可能是股票短期内对公告或传言的反应,不一定能持续上涨。

如何优化?

可以逐步增加其他技术指标和基本面因素用于选股,比如MACD、RSI、市盈率、市净率、股息率等基本面指标。同时,可以加入一些辅助指标,例如成交量、布林带、动能指标等,综合考虑更多因素。此外,可以加入股票的历史走势和趋势等因素,以更好地分析股票的潜在风险。

最终的选股逻辑

对于A股市场来说,选股逻辑为:振幅大于1、股价为18.5元、KDJ随机指标(K)增长值。可根据实际投资需求进行修改,增加其他技术指标和基本面因素,加入历史趋势和预测分析等。

同花顺指标公式代码参考

# 振幅大于1
SELECT1 = (HIGH-LOW)/HIGH > 0.01
# 股价为18.5元
SELECT2 = CLOSE == 18.5
# KDJ随机指标(K)增长值
SELECT3 = REF((RSI(CLOSE, 14) - LLV(RSI(CLOSE, 14), 14)) / (HHV(RSI(CLOSE, 14),14) - LLV(RSI(CLOSE, 14),14)) * 100,1) > REF((RSI(CLOSE, 14) - LLV(RSI(CLOSE, 14), 14)) / (HHV(RSI(CLOSE, 14),14) - LLV(RSI(CLOSE, 14),14)) * 100,2)

SELECT = SELECT1 AND SELECT2 AND SELECT3

以上为计算选股逻辑的指标公式。选股指标为:振幅大于1、股价为18.5元、KDJ随机指标(K)增长值。可根据实际投资需求进行修改。

Python代码参考

import pandas as pd
import tushare as ts

def get_selected_stocks():
    # 获取tushare连接
    ts.set_token('Your Token')
    pro = ts.pro_api()

    # 获取A股市场所有的股票
    all_stocks = [ts_code for ts_code, name, industry in pro.stock_basic(fields='ts_code,name,industry', exchange='', list_status='L').values.tolist() if name[0] != 'S']

    # 计算选股指标并依此进行选股
    selected_stocks = []
    for ts_code in all_stocks:
        all_data = pro.stock_company(ts_code=ts_code, fields='pro_name,concept_name,industry,exchange,list_date,total_equity,market_type,holders')
        if all_data.empty or all_data.iloc[0]['total_equity'] == 0 or (pd.Timestamp.now() - pd.to_datetime(all_data.iloc[0]['list_date'])).days < 365:
            continue

        daily_data = pro.daily(ts_code=ts_code, end_date=(pd.Timestamp.now() - pd.Timedelta(days=1)).strftime('%Y%m%d'), fields='high,low,open,close,vol')
        if daily_data.empty or daily_data['low'].iloc[-1] >= daily_data['low'].iloc[0] or daily_data['close'].iloc[-1] != daily_data['open'].iloc[-1]:
            continue

        if daily_data['close'].iloc[-1] / daily_data['close'].iloc[-2] - 1 <= 0.01:
            continue

        kdj_data = pro.index_daily(ts_code='000001.SH', trade_date=(pd.Timestamp.now() - pd.Timedelta(days=2)).strftime('%Y%m%d'))[['open','high','low','close']]
        kdj_value = round((100 - 100 / (1 + (kdj_data['low'].iloc[-9:-1].min() / kdj_data['close'].iloc[-1] - 1) * 3 + kdj_data['high'].iloc[-9:-1].max() / kdj_data['close'].iloc[-1] * 2 + kdj_data['close'].iloc[-1] / kdj_data['close'].iloc[-9:-1].min() * 3) * 0.6667), 2)
        kdj_value_last = round((100 - 100 / (1 + (kdj_data['low'].iloc[-8:].min() / kdj_data['close'].iloc[-1] - 1) * 3 + kdj_data['high'].iloc[-8:].max() / kdj_data['close'].iloc[-1] * 2 + kdj_data['close'].iloc[-1] / kdj_data['close'].iloc[-8:].min() * 3) * 0.6667), 2)
        if kdj_value <= kdj_value_last:
            continue

        selected_stocks.append((all_data.iloc[0]['pro_name'], ts_code))

    selected_stocks_sorted = sorted(selected_stocks, key=lambda x: pro.moneyflow(ts_code=x[1], trade_date=(pd.Timestamp.now() - pd.Timedelta(days=1)).strftime('%Y%m%d'))['net_mf_vol'].iloc[0]
        if pd.notna(pro.moneyflow(ts_code=x[1], trade_date=(pd.Timestamp.now() - pd.Timedelta(days=2)).strftime('%Y%m%d'))['net_mf_vol'].iloc[0]) 
        else 0, reverse=True)
    return selected_stocks_sorted

以上为Python代码实现,选股逻辑为:振幅大于1、股价为18.5元、KDJ随机指标(K)增长值。其中,KDJ随机指标(K)增长值采用的是000001.SH上证指数的计算,可根据实际需求进行修改。

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

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

    模板如何使用?

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


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

评论

需要帮助?

试试AI小助手吧