问财量化选股策略逻辑
选股逻辑为振幅大于1,10日涨幅大于0小于35,2021年。
选股逻辑分析
- 振幅大于1可以表示市场波动性,意味着更高的风险和收益机会。
- 筛选10日涨幅大于0小于35的股票,可以避免选择过度涨价的股票,但仍有一定的风险。
- 仅关注2021年的股票可能忽略掉过去的表现,存在一定的风险。
有何风险?
- 过度依赖单一的选股条件可能会忽略其他重要的因素,存在一定的风险。
- 仅关注2021年的股票可能忽略了一些长期表现不错的股票。
- 历史表现不代表未来表现,存在选股风险。
如何优化?
- 结合其他技术指标进一步调整选股条件,如MACD等。
- 给出更长时间段的表现,避免过分依赖单一时间段。
- 谨慎对待单一指标的使用,结合多方面因素进行判断。
最终的选股逻辑
选股逻辑包括振幅大于1,10日涨幅大于0小于35,近一年内表现不错的股票。
同花顺指标公式代码参考
YEB AND (CLOSE > MA(C, 10)) AND ((HIGH - LOW) / REF(C, 1) > 0.01)
AND (CLOSE / REF(CLOSE, 10) - 1 > 0) AND (CLOSE / REF(CLOSE, 10) - 1 < 0.35)
AND (Y > REF(Y, 1))
python代码参考
import akshare as ak
from datetime import datetime, timedelta
def select(df, start_date):
end_date = datetime.now().strftime("%Y-%m-%d")
df['ma10'] = df['收盘价'].rolling(window=10).mean()
df = df[(df['股票价格'] > df['ma10'] * 0.95) & (df['股票价格'] < df['ma10'] * 1.05)]
df = df[(df['最高价'] - df['最低价']) / df['收盘价'].shift(1) > 0.01]
df['涨幅'] = df['收盘价'].pct_change(10)
df = df[(df['涨幅'] > 0) & (df['涨幅'] < 0.35)]
start_date_obj = datetime.strptime(start_date, "%Y-%m-%d")
df['年份'] = df['日期'].apply(lambda x: int(x[:4]))
df = df[(df['年份'] >= start_date_obj.year)]
return df
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。
