问财量化选股策略逻辑
选股逻辑为:选择换手率在3%~12%之间、买一量大于卖一量、10天内涨停天数大于2的股票。
选股逻辑分析
该选股策略主要从交易活跃度、市场参与度、短期涨势等角度综合考虑,选取具有一定上涨潜力的股票。
有何风险?
该选股策略过于依赖短期涨势因素,可能导致选出的股票具有一定的投机性质,而非投资价值。此外,涨停股票存在短期大幅调整的风险,因此选股时需要谨慎。
如何优化?
除了选股时考虑交易活跃度和短期涨势外,增加其他技术指标,如均线系统、趋势指标等,可以提高筛选出有较好表现的股票的概率。此外,可以结合公司基本面、宏观经济等因素进行选股筛选,更加全面地综合考虑选股因素。
最终的选股逻辑
在换手率在3%~12%之间,买一量大于卖一量,10天内涨停天数大于2的股票中,按照涨幅从高到低排序,选取前50只股票。
同花顺指标公式代码参考
SELECT A.SYMBOL FROM (
SELECT SYMBOL FROM GDH WHERE NAME = '换手率'
AND (CAST(DATA AS NUMBER) > 3) AND (CAST(DATA AS NUMBER) < 12)
AND SYMBOL IN (SELECT STOCK_CODE FROM STOCK_BASIC WHERE MARKET = '主板' AND LIST_STATUS = '上市')
AND SYMBOL IN (SELECT STOCK_CODE FROM SDB WHERE NAME = '买一' AND CAST(DATA AS NUMBER) > CAST(FDATA AS NUMBER))
AND SYMBOL IN (SELECT SYMBOL FROM TRADE_DAILY WHERE SYMBOL IN (
SELECT SYMBOL FROM (SELECT SYMBOL, COUNT(*) DAY_CNT FROM TRADE_DAILY WHERE CHG_RATE = 10
AND TRADE_DATE >= (SELECT TRADE_DATE FROM TRADE_CALENDAR WHERE OPENED = 1 AND TRADE_DATE > DATEADD(DAY, -10, GETDATE()))
GROUP BY SYMBOL) WHERE DAY_CNT > 2))
) A
LEFT JOIN (
SELECT SYMBOL FROM (
SELECT SYMBOL, SUM(HOLD_RATIO) RATIO FROM STOCK_HOLDERS WHERE TRADE_DATE = '2022-04-22'
GROUP BY SYMBOL HAVING SUM(HOLD_RATIO) > 0.2
)
) B ON A.SYMBOL = B.SYMBOL
WHERE B.SYMBOL IS NULL
ORDER BY A.CHG DESC
WHERE ROWNUM <= 50;
python代码参考
import pandas as pd
import tushare as ts
def select_stocks():
pro = ts.pro_api()
# 查询挂单大量大于卖单的股票
market_df = pro.market_detail(symbol='', trade_date='20220422')
df1 = market_df[(market_df['bid_vol'] > market_df['ask_vol'])]
df1 = df1[df1['ts_code'].str.startswith('0')]
# 查询10天内涨停天数大于2的股票
trade_cal_df = pro.trade_cal(start_date='20220413', end_date='20220422')
trade_date_list = trade_cal_df[trade_cal_df['is_open'] == 1]['cal_date'][-10:].tolist()
daily_df = pro.daily(trade_date=trade_date_list[-1], fields='ts_code,trade_date,pct_chg')
for i in range(len(trade_date_list)-2, -1, -1):
daily_df1 = pro.daily(trade_date=trade_date_list[i], fields='ts_code,trade_date,pct_chg')
daily_df = pd.concat([daily_df, daily_df1], axis=0)
daily_df = daily_df[daily_df['pct_chg'] == 10]
df1 = pd.merge(df1, daily_df, on='ts_code', how='inner')
df1 = df1.groupby(['ts_code']).size().reset_index(name='cnt')
df1 = df1[df1['cnt'] > 2]
df1.drop(columns=['cnt'], inplace=True)
# 按换手率筛选股票
daily_basic_df = pro.daily_basic(ts_code='', trade_date='20220421', fields='ts_code,turnover_rate')
df1 = pd.merge(df1, daily_basic_df, on='ts_code', how='inner')
df1 = df1[(df1['turnover_rate'] > 3) & (df1['turnover_rate'] < 12)]
# 按市场筛选股票
df1 = df1[df1['ts_code'].str.startswith('0')]
# 按买卖盘挂单量筛选股票
sdb_df = pro.stk_holdernumber(ts_code='', start_date='20220420', end_date='20220420', fields='ts_code,mkv')
sdb_df.rename(columns={'ts_code': 'symbol'}, inplace=True)
df1 = pd.merge(df1, sdb_df, on='symbol', how='inner')
df1 = df1[(df1['buy_sm_vol'] > df1['sell_sm_vol']) & (df1['buy_sm_vol'] > df1['mkv'])]
# 按涨幅排序
df1 = df1.sort_values('pct_chg', ascending=False)
# 合并所有指标,返回选股结果
return df1[:50]['ts_code']
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。
