(supermind量化-)振幅大于1、上市大于、KDJ刚形成金叉_

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

问财量化选股策略逻辑

本选股策略选取振幅大于1、上市时间大于一年、KDJ刚形成金叉的股票。

选股逻辑分析

振幅大于1和上市时间大于一年的逻辑相同:前者可以筛选出市场活跃性较强的股票,后者可以筛选出相对稳定的股票。KDJ指标是一种反映市场买卖情况的技术指标,能够准确判断股票的买卖趋势,并且KDJ值低于20时视为超卖区,高于80时视为超买区,从而KDJ金叉可以判断出市场底部,是一个非常重要的选股指标。KDJ刚形成金叉可以筛选出市场底部并且刚开始上涨的个股。综合三个指标,选出的股票更有上涨潜力。

有何风险?

该选股策略选出的股票可能并没有达到预期效果,因为振幅和上市时间只是市场活跃性和股票稳定性的指标,与股票本身的基本面和技术面相关程度不够。同时,KDJ刚形成金叉只是短期判断,不能完全代表股票的趋势是否改变。

如何优化?

可以在股票基本面上加入其他筛选条件。比如,加入市盈率、市净率等基本面指标筛选优质股票。可以在KDJ指标上加入其他筛选条件,比如KDJ金叉之前的走势、KDJ并不处于超买区等。

最终的选股逻辑

本选股策略选取振幅大于1、上市时间大于一年、KDJ刚形成金叉的股票。

同花顺指标公式代码参考

振幅:
VAR1:=(ABS(HIGH-LOW)/REF(CLOSE,1))*100;
VAR1>1

上市时间:
DATEDIFF(LISTDATE,TODAY)>365

KDJ刚形成金叉:
CROSS(KDJ(9,3,3)的K线,KDJ(9,3,3)的D线) AND REF(KDJ(9,3,3)的K线,1)<=REF(KDJ(9,3,3)的D线,1) AND KDJ(9,3,3)的K线<=KDJ(9,3,3)的D线 AND REF(KDJ(9,3,3)的K线,1)<=REF(KDJ(9,3,3)的J线,1) AND KDJ(9,3,3)的K线>=KDJ(9,3,3)的J线

python代码参考

# 引入Tushare库
import tushare as ts

# 连接Tushare库
pro = ts.pro_api()

def select_stocks(n):
    selected_stocks = []

    today = pro.trade_cal(exchange='', is_open='1')["cal_date"].values[-1]

    for i in range(3):
        # 筛选出振幅大于1、上市时间大于一年的股票
        basic = pro.stock_basic(list_status='L', fields='ts_code,name,list_date')
        basic = basic[basic["list_date"].apply(int).apply(lambda x: (int(today) - x) > 365)]
        quotes = pro.daily(ts_code=basic["ts_code"].str.cat(sep=","), start_date=int(today)-20, end_date=int(today)-1, fields='ts_code,open,close,high,low')
        quotes["var1"] = (abs(quotes["high"] - quotes["low"]) / quotes["close"].shift(1)) * 100
        quotes = quotes[quotes["var1"] > 1]
        if len(quotes) == 0:
            continue

        # 筛选出KDJ刚形成金叉的股票
        for code in quotes["ts_code"]:
            if len(selected_stocks) >= n:
                break

            quote_info = pro.daily(ts_code=code, start_date=int(today)-20, end_date=int(today)-1, fields='ts_code,open,close,high,low')
            kdj_info = pro.query('daily_basic', ts_code=code, trade_date=today, fields='ts_code,kdj_k,kdj_d,kdj_j')
            kdj_info_1 = pro.query('daily_basic', ts_code=code, trade_date=int(today)-10, fields='ts_code,kdj_k,kdj_d,kdj_j')
            if len(quote_info) < 10 or len(kdj_info) == 0 or len(kdj_info_1) == 0:
                continue

            if kdj_info["kdj_k"].values[0] > kdj_info_1["kdj_k"].values[0] and kdj_info["kdj_k"].values[0] <= kdj_info["kdj_d"].values[0] and kdj_info["kdj_k"].values[0] >= kdj_info["kdj_j"].values[0] and kdj_info_1["kdj_k"].values[0] <= kdj_info_1["kdj_d"].values[0] and kdj_info["kdj_d"].values[0] > kdj_info_1["kdj_d"].values[0]:
                selected_stocks.append(code)

                if len(selected_stocks) >= n:
                    break

        if len(selected_stocks) >= n:
            break

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

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

    模板如何使用?

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


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

评论