问财量化选股策略逻辑
选股逻辑为:选择换手率在3%~12%之间、买一量大于卖一量、价格低于12元的股票。
选股逻辑分析
该选股策略主要考虑了股票的市场活跃度、市场参与度以及股价水平的因素,通过选股筛选出市场活跃度和参与度较高的、股价相对较低的股票。
有何风险?
该选股策略只考虑了几个特定指标,没有考虑技术分析指标、市场情绪等因素的影响,因此其选股结果可能存在一定的盲区。同时,股价与公司基本面和业绩并不一定完全相关,仅凭股价水平筛选股票也具有一定风险。
如何优化?
可以引入其他基本面、技术分析指标、市场情绪等指标,如市净率、财务报表、企业新闻、资金流向等,使选股策略更具全面性。同时,应该结合股票的历史行情和板块行情等因素,进一步优化选股策略。
最终的选股逻辑
在换手率在3%~12%之间、买一量大于卖一量、价格低于12元的股票中,按换手率从大到小排序,选出前50个股票。
同花顺指标公式代码参考
SELECT STOCKCODE FROM (
SELECT STOCKCODE FROM BLOCK_STOCK WHERE BLOCKID = 'HS300'
AND STOCKCODE IN (SELECT STOCK_CODE FROM STOCK_BASIC WHERE MARKET='主板' AND LIST_STATUS='上市' AND IS_ST=0 AND IS_OPEN='1')
AND STOCKCODE IN
(SELECT STOCK_CODE FROM SDB WHERE NAME = '买一' AND (CAST(DATA AS NUMBER) > CAST(FDATA AS NUMBER)))
AND STOCKCODE IN (SELECT STOCK_CODE FROM GDH WHERE NAME = '换手率' AND (CAST(DATA AS NUMBER) > 3) AND (CAST(DATA AS NUMBER) < 12)))
AND STOCKCODE IN (SELECT STOCK_CODE FROM GDH WHERE NAME = '最新' AND (CAST(DATA AS NUMBER) < 12)))
ORDER BY (SELECT AVG(DATA) AS AVG_RQSB FROM (SELECT DATA FROM SDB WHERE STOCK_CODE=A.STOCKCODE AND NAME='资金流向' AND NAME_DESC='日前收买' ORDER BY DATE. DESC) WHERE ROWNUM<=5) DESC
WHERE ROWNUM <= 50;
python代码参考
import pandas as pd
import tushare as ts
def select_stocks():
pro = ts.pro_api()
# 查询挂单大量大于卖单、价格低于12元的股票
market_df = pro.market_detail(symbol='', trade_date='20220422')
df1 = market_df[(market_df['bid_vol'] > market_df['ask_vol'])]
df1 = df1[(df1['last_price'] < 12)]
# 按换手率筛选股票
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', '3', '6'))]
# 按买卖盘挂单量筛选股票
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('turnover_rate', ascending=False)
# 合并所有指标,按换手率从大到小排序,返回选股结果
return df1[:50]['ts_code']
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。


