问财量化选股策略逻辑
选股逻辑包括三个条件:选择元宇宙行业的股票、机构动向大于0、9点25分涨幅小于6%。根据这些条件进行选股,进行投资。
选股逻辑分析
该选股策略主要围绕以下三个条件进行选股:
- 选取元宇宙行业中的股票,因为元宇宙领域具有较高的成长性和隐含收益;
- 机构动向具有预测性和引导作用,选择机构买入股票可以获得较好的资本回报;
- 选择9点25分涨幅小于6%的个股,可以在不买入热门高涨个股的情况下获得相对较低的成本。
综合以上条件,选择符合条件的个股进行投资。
有何风险?
- 行业投资的风险因素较大,选股策略难以捕捉行业整体动向;
- 仅考虑股票在9点25分前的涨幅不一定能够真正反映出其短期走势;
- 如果市场整体大涨,该策略可能错失获取更高收益的机会。
如何优化?
- 加入行业板块轮动因素,进行相对强势的行业和个股选择;
- 综合考虑不同时间段的股票表现情况,不只是考虑9点25分涨幅;
- 加入基本面数据和技术指标进行综合考虑股票的投资价值。
最终的选股逻辑
该选股策略选择元宇宙行业中,机构动向大于0,9点25分涨幅小于6%的股票进行投资。
同花顺指标公式代码参考
元宇宙行业:GNBK("gnxq");
机构动向:DRS_M("zlltgtzb");
9点25分涨幅:REF((HIGH-OPEN)/OPEN, 0)>0, REF((HIGH-OPEN)/OPEN, 0)<0.06
选股公式:GNBK("gnxq") AND DRS_M("zlltgtzb") AND REF((HIGH-OPEN)/OPEN, 0)>0 AND REF((HIGH-OPEN)/OPEN, 0)<0.06
Python代码参考
import pandas as pd
import tushare as ts
def stock_selector():
ts.set_token('your_token')
pro = ts.pro_api()
data1 = pro.query('stock_basic', exchange='', list_status='L', fields='ts_code,name,industry')
data1 = data1[(data1['name'].str.contains('元宇宙')) & (data1['industry'] != '银行')]
data2 = pro.query('fii_lgt_list', start_date='20220308', end_date='20220308', fields='ts_code, buy_value, sell_value, net_value')
data2 = data2.groupby(by='ts_code').sum()
data2['net'] = data2['net_value'] / 1e8
data2 = data2.sort_values(by='net', ascending=False)
data2 = data2.iloc[0:100, :]
data2['rank'] = range(1, 101)
data2 = data2.loc[:, ['rank']]
data4 = pro.query('daily_basic', trade_date='20220307', fields='ts_code, close, open, high')
data4['morning_rise'] = (data4['high']-data4['open'])/data4['open']
data4 = data4[data4['morning_rise']<0.06]
data5 = pro.query('fina_mainbz', ts_code='', end_date='20220308', fields='ts_code,main_business_profit')
data5 = data5[data5['main_business_profit'] > 0]
data6 = pro.query('daily_basic', trade_date='20220307', ts_code='', fields='ts_code, float_share')
data6 = data6.groupby(by='ts_code').sum()
data6 = data6.sort_values(by='float_share', ascending=False)
data6 = data6.iloc[0:100, :]
data6['rank'] = range(1, 101)
data6 = data6.loc[:, ['rank']]
data7 = pro.moneyflow(trade_date='20220308', fields='ts_code, trade_date, buy_sm_vol, sell_sm_vol, buy_md_vol, \
sell_md_vol, buy_lg_vol, sell_lg_vol, buy_elg_vol, sell_elg_vol, buy_value, sell_value, net_mf_vol')
data7 = pd.concat([data7.loc[:, 'ts_code'], data7.loc[:, 'net_mf_vol']], axis=1)
data7.columns = ['ts_code', 'net_inst_buy']
data7 = data7.loc[data7.net_inst_buy > 0, :]
data8 = pd.concat([data1.loc[:, 'ts_code'], data2, data4.loc[:, 'morning_rise'], data5.loc[:, 'main_business_profit'], \
axis=1)
data8.columns = ['ts_code', 'ddjlr_rank','morning_rise', 'main_business_profit']
data8 = pd.merge(data8,data7,on='ts_code')
data8 = pd.merge(data8, data6, on='ts_code')
data8 = data8.sort_values(by='ddjlr_rank', ascending=True)
data8 = data8.iloc[0:50, :]
return data8
## 如何进行量化策略实盘?
请把您优化好的选股语句放入文章最下面模板的选股语句中即可。
select_sentence = '市值小于100亿' #选股语句。
模板如何使用?
点击图标右上方的复制按钮,复制到自己的账户即可使用模板进行回测。
## 如果有任何问题请添加 下方的二维码进群提问。
