问财量化选股策略逻辑
选股逻辑:MACD指标零轴以上,归属母公司股东的净利润同比增长率大于20%小于等于100%,近25个交易日有单日涨幅大于等于百分之10。
选股逻辑作为第一个段落放入标题为 ## 问财量化选股策略逻辑 的段落中。分析以上的选股逻辑(每个逻辑以 "," 进行分隔),分析选股的逻辑(放入标题为 ## 选股逻辑分析 的段落),有什么风险?(放入标题为 ## 有何风险? 的段落)如何优化?(放入标题为 ## 如何优化? 的段落)并最终给出完善选股逻辑(放入标题为 ## 最终的选股逻辑 的段落),请用Markdown格式。
选股逻辑分析
该选股策略基于MACD指标、归属母公司股东的净利润同比增长率和股票的涨幅进行筛选,旨在捕捉近期走势较好,有良好基本面的股票。通过选取有涨幅的股票,找到近期热门的个股。
有何风险?
以下是该选股策略面临的可能风险:
- MACD指标可能存在滞后性,选取MACD指标零轴以上的股票存在一定的风险;
- 只考虑单一财务指标可能忽略了公司的整体财务状况,及其他公司运营情况,如负债情况,资产质量等;
- 近25个交易日有单日涨幅大于等于百分之10可能是短期买卖行为的结果,存在较大的市场风险。
如何优化?
以下是几个优化该选股策略的建议:
- 可以引入更为全面的财务指标,如ROE、ROA、资产负债率等,并适当放宽筛选条件,提高综合考虑的能力;
- 引入更复杂的机器学习算法,对股票进行分析和预测,提高选股精度;
- 可以结合技术指标和基本面指标,仅选取长期走势良好,而非短期涨幅较大的股票,提高选股的稳定性。
最终的选股逻辑
选股策略:MACD指标零轴以上,归属母公司股东的净利润同比增长率大于20%小于等于100%,近25个交易日有单日涨幅大于等于百分之10。
同花顺指标公式代码参考
SELECT S_CODE
FROM (
SELECT S_CODE,
MACD(S_CODE, 12, 26, 9) AS MACD,
CMPR(S_CODE, MSEBL, 20, 100, 4, 'END_DATE', 1) AS NET_PROFIT_YOY_RATIO,
IF(IFNULL(ARRAYGET(H_EQUIP_STAT_S(S_CODE, 'incr_r', 25, 0), 0), 0) > 0.1, 1, 0) AS DAY_RISE,
LEFT(S_CODE, 2) AS STOCK_ABBR_NAME
FROM STOCK_OHLC_PRICE
WHERE
-- MACD指标零轴以上
MACD(S_CODE, 12, 26, 9) > 0
-- 归属母公司股东的净利润同比增长率大于20%小于等于100%
AND CMPR(S_CODE, MSEBL, 20, 100, 4, 'END_DATE', 1) >= 0
-- 近25个交易日有单日涨幅大于等于百分之10
AND IF(IFNULL(ARRAYGET(H_EQUIP_STAT_S(S_CODE, 'incr_r', 25, 0), 0), 0) > 0.1, 1, 0) = 1
)
ORDER BY AVGTRDNUM(30)/AVGTRDNUM(180) DESC
Python代码参考
# 初始化
def initialize(context):
set_benchmark('000300.XSHG')
# 获取所有股票
g.all_stocks = get_all_securities(['stock']).index.tolist()
g.selected_stocks = []
# 每天运行选股逻辑
run_daily(select_stocks, time_rule=market_open(hour=0.5))
# 选股逻辑
def select_stocks(context):
# 遍历所有股票,进行筛选
selected_stocks = []
for stock in g.all_stocks:
# 如果MACD指标零轴以下,跳过
dif, dea, macd = talib.MACD(get_price(stock, frequency='1d', count=200, end_date=context.previous_date, fields=['open', 'close', 'high', 'low']), fastperiod=12, slowperiod=26, signalperiod=9)
if macd[-1] <= 0:
continue
# 如果净利润同比增长率不符合条件,跳过
q1 = query(income.code, income.netProfitYoYRatio).filter(
income.code == stock, income.statDate >= (datetime.datetime(2021,1,1)))
data1 = get_fundamentals(q1)
if data1.empty or data1['net_profit_yoy_ratio'][0] <= 0.2 or data1['net_profit_yoy_ratio'][0] > 1:
continue
# 如果涨幅不符合条件,跳过
data2 = H_EQUIP_STAT_S(stock, 'incr_r', 25, 0)
if not any([r > 0.1 for r in data2]):
continue
# 添加到选择列表中
selected_stocks.append(stock)
# 按照成交量排序,选择前5个
selected_stocks = sorted(selected_stocks, key=lambda s: get_price(s, count=1, end_date=context.current_dt, frequency='1d', fields=['volume'])['volume'][0], reverse=True)[:5]
g.selected_stocks = selected_stocks
# 卖出不在选股结果中的股票
for stock in context.portfolio.positions:
if stock not in selected_stocks:
order_target(stock, 0)
# 买入新选出的股票
for stock in selected_stocks:
if stock not in context.portfolio.positions:
order_target_value(stock, context.portfolio.total_value/5)
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。


