问财量化选股策略逻辑
选股逻辑:振幅大于1,周线红柱,换手率3%-12%。
选股逻辑分析
该选股逻辑综合考虑了技术面和基本面指标,振幅大于1、周线红柱可以反映出较强的技术面趋势,换手率3%-12%可以代表着股票的活跃程度恰到好处,有一定的上涨潜力。同时,该选股逻辑操作简单,容易理解,比较适用于初学者。通过筛选符合条件的股票,可以较为精准地选出有上涨潜力的好股票。
有何风险?
该选股逻辑虽然考虑了多个技术面和基本面指标,但仍然忽略了一些其他重要的可选指标,如市场情绪、金融资产走势等,可能会对决策产生一定的限制。同时,如果市场行情发生重大变化,该选股策略可能会失效。
如何优化?
为了提高该选股逻辑的可靠性和有效性,建议将该选股策略与其他技术面和基本面指标组合起来,如成交量、KDJ指标、市盈率、市净率等,来更全面地评估股票的趋势。此外,需要根据不同行情和时间周期,动态地调整选股策略参数,以提高效果。另外,需要关注公司基本面和行业发展趋势,结合股票的技术面指标评估股票的价值。
最终的选股逻辑
完善选股逻辑如下:
1.振幅大于1;
2.周线红柱;
3.换手率在3%-12%之间;
4.结合其他技术面和基本面指标。
同花顺指标公式代码参考
以下是同花顺实现该选股策略的指标公式代码:
C1 = AMP() > 1;
C2 = WEEKLY(COLOR(MACD(12, 26, 9), RED)) > 0;
C3 = BETWEEN(TURN, 3, 12);
SELECTOR = C1 AND C2 AND C3;
RESULT = SELECTOR;
其中,BETWEEN(TURN, 3, 12)
表示换手率在3%-12%之间。
Python代码参考
以下是Python实现该选股策略的部分代码:
# 筛选符合条件的股票
def select_stocks(start_date, end_date):
selected_stocks = []
for stock in stocks:
# 获取该股票在指定时间内的周线和日线数据
df_weekly_kline = get_price(stock, start_date=start_date, end_date=end_date, frequency='weekly', fields=['open', 'high', 'low', 'close', 'volume'], skip_paused=True, fq='pre')
df_daily_kline = get_price(stock, start_date=start_date, end_date=end_date, frequency='daily', fields=['open', 'high', 'low', 'close', 'volume'], skip_paused=True, fq='pre')
# 计算振幅指标,判断是否符合选股逻辑
c1 = df_daily_kline['high'].std() > 1
# 计算MACD指标的周线红柱和零轴以上,判断是否符合选股逻辑
macd_weekly = MACD(df_weekly_kline, 12, 26, 9)
c2 = macd_weekly.iloc[-1]['macd'] > 0 and macd_weekly.iloc[-1]['diff'] > 0
# 判断换手率在3%-12%之间,判断是否符合选股逻辑
turn = df_daily_kline['volume'].sum() / len(df_daily_kline) / get_ipo_date(stock).day
c3 = 0.03 <= turn <= 0.12
# 判断是否符合选股逻辑
if c1 and c2 and c3:
selected_stocks.append(stock)
return selected_stocks
result = select_stocks('2022-01-01', '2022-12-31')
print(result)
以上代码仅供参考,具体实现还需要根据自身需求进行调整。
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。
