问财量化选股策略逻辑
本选股策略选取振幅大于1,(昨日换手率*(今日竞价成交量/昨日成交量))在0.5到2之间,并且昨日有龙虎榜交易的股票。这些条件可以筛选出波动性较好、且有较高交易活跃度的股票。
选股逻辑分析
本选股策略主要考虑了股票价格波动情况、交易活跃度和龙虎榜交易情况。选股条件比较全面,可以筛选出波动性较好且交易活跃的股票,并且有较高潜在交易活跃度的股票。
有何风险?
由于本选股策略只考虑了股票价格波动情况、交易活跃度和龙虎榜交易情况,没有综合考虑多种因素,因此存在较大的局限性。在投资时,应该考虑更多股票基本面和财务数据等因素。
此外,只考虑了昨日龙虎榜交易情况,可能忽略了其他潜在的交易活跃度因素。因此,需要进一步细化交易活跃度相关的选股条件。
如何优化?
应该在考虑股票价格波动情况、交易活跃度和龙虎榜交易情况的基础上,进一步细化选股条件,比如可以考虑成交量和相对强势指标等。同时,需要结合基本面和财务数据等因素,从而确保综合考虑多种因子的选股策略。
此外,可以考虑引入机器学习等技术,优化选股策略。
最终的选股逻辑
本选股策略选取振幅大于1,(昨日换手率*(今日竞价成交量/昨日成交量))在0.5到2之间,并且昨日有龙虎榜交易的股票。在此基础上,可以加入成交量、相对强势指标等因素,同时结合基本面和财务数据,构建综合考虑多种因素的选股策略。
同花顺指标公式代码参考
通达信指标公式:CCI(14)<-100
Python代码参考
import tushare as ts
import pandas as pd
import numpy as np
import talib
pro = ts.pro_api()
def select_stocks(n):
selected_stocks = []
for code in pro.query('stock_basic', exchange='', list_status='L', fields='ts_code,name,list_date,list_status,total_mv,circ_mv')["ts_code"]:
if len(selected_stocks) >= n:
break
db = pro.daily(ts_code=code, start_date=(datetime.now() - timedelta(days=365)).strftime("%Y%m%d"),
end_date=datetime.now().strftime("%Y%m%d"), fields='open,high,low,close,vol,total_mv,circ_mv')
if db.empty or len(db) < 250:
continue
# 筛选条件
db['amplitude'] = (db['high'] - db['low']) / db['pre_close']
db['turnover_volume'] = (db['turnover_rate'] * db['vol'] / 100) # 换手量
db['yesterday_notional'] = db['pre_close'] * db['vol'] / 10000 # 昨日成交额
db['jy_notional'] = db['open'] * db['vol'] / 10000 # 竞价成交额
db['hy_notional'] = db['close'] * db['vol'] / 10000 # 当日盘中成交额
db_selected = db[(db['amplitude'] > 1) & (db['turnover_volume'].shift(2) * (db['jy_notional'] / db['yesterday_notional']) > 0.5) &
(db['turnover_volume'].shift(2) * (db['jy_notional'] / db['yesterday_notional']) < 2) &
(db['turnover_rate'] > 4) & (db['trade_date'] == (datetime.today() - timedelta(days=1)).strftime("%Y%m%d"))]
# 加入CCI指标
cci = talib.CCI(db['high'].values, db['low'].values, db['close'].values, timeperiod=14)[-1]
if not db_selected.empty and cci < -100:
selected_stocks.append({'code':code, 'last_close': db.iloc[-1]['close']})
# 根据收盘价排序选择前n个股票
df = pd.DataFrame(selected_stocks)
df_selected = df.sort_values('last_close', ascending=False)[:n]
selected_stocks = list(df_selected['code'])
return selected_stocks
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。
