Skip to content

Latest commit

 

History

History
187 lines (161 loc) · 11.4 KB

175.md

File metadata and controls

187 lines (161 loc) · 11.4 KB

历史的十一月板块涨幅

来源:https://uqer.io/community/share/563c8065f9f06c713ddfeb6d

大盘又开始疯长了,还记嘚去年十一月吗 ?

#获得行业信息
def GetEquIndustry(universe,field):    
    num = 100
    cnt_num = len(universe)/num
    if cnt_num > 0:
        df = pd.DataFrame({})
        for i in range(cnt_num) :
            sub_df = DataAPI.EquIndustryGet(secID=universe[i*num:(i+1)*num],field=field)
            df = pd.concat([df,sub_df])
        if (i+1)*num != len(universe):
            sub_df = DataAPI.EquIndustryGet(secID=universe[(i+1)*num:],field=field)
            df = pd.concat([df,sub_df])
    else:
        df = DataAPI.EquIndustryGet(secID=universe,field=field)
    return df
from CAL.PyCAL import *
import pandas as pd
cal = Calendar('China.SSE')
universe = DataAPI.EquGet(equTypeCD='A')['secID'].tolist()    #获得全A股的secID
id2nm = lambda x:x[0:6]
tk_list_A = map(id2nm,universe)    #获得全A股的ticker

Ind_info = GetEquIndustry(universe = universe ,field=['ticker','secShortName','industryName2'])    #获得个股的申万行业分类
Ind_info_gp = Ind_info.groupby('industryName2')#按照行业分组

Ind_tks_dic = {}    #获得每个行业包含的股票
for ind_nm,sub_info in Ind_info_gp:
    Ind_tks_dic[ind_nm] = sub_info.drop_duplicates('ticker')['ticker'].tolist()    
from pandas import DataFrame,Series
from CAL.PyCAL import *
cal = Calendar('China.SSE')
field = ['ticker','secShortName','tradeDate','preClosePrice','closePrice','turnoverValue']
#时间轴(开始时间)
time = ['20141031', '20131031', '20121031', '20111031', '20101031']
#保存各个时间段的数据
Data_time = {}
#保存各个时间段的股票名字
tk_nm_dic ={}

# 时间稍慢
for s in time : 
    Data_time[s] = DataFrame()
    for x in universe :        
        try : 
            data_temp = DataAPI.MktEqudAdjGet( secID = x , field =field , beginDate = s , endDate = cal.advanceDate(s,'1M', BizDayConvention.Following).strftime('%Y%m%d'))   
            data_temp['marketValue']  = DataAPI.MktEqudGet(secID = x ,field ='marketValue' , beginDate = s , endDate = cal.advanceDate(s,'1M', BizDayConvention.Following).strftime('%Y%m%d')) 
            Data_time[s] = pd.concat([Data_time[s],data_temp])  
        except : 
            continue
    tk_nm_dic[s] = dict(zip(Data_time[s]['ticker'],Data_time[s]['secShortName']))                                    # 获得个股ticker与名称的对应字典

for s in Data_time.values() :         
    s['tradeDate'] = pd.to_datetime(s['tradeDate'])                                         # 将tradeDate这一列的格式由string改为datetime
    s['increase'] = s['closePrice']/s['preClosePrice']                                      # 获得个股每天的收益    
# 股票数据统计
Stock_Data = {}
for s in Data_time.keys() :    
    Stock_dict = {'ticker':[],'income':[],'turnoverValue':[] ,'marketValue' :[]} 
    # 获得每个时间段的Data计算个股的收益和平均市值
    for tk,sub_info in Data_time[s].groupby('ticker') :
        income = sub_info['increase'].prod()-1                     # 获得在这段时间内该股的涨幅    
        mkt_value = sub_info['marketValue'].sum()/len(sub_info)     
        turnoverValue_avg = sub_info['turnoverValue'].sum()/len(sub_info)   
        Stock_dict['ticker'].append(tk)
        Stock_dict['income'].append(income)
        Stock_dict['marketValue'].append(mkt_value)
        Stock_dict['turnoverValue'].append(turnoverValue_avg)
    # 返回时间为Key的个股数据
    Stock_Data[s] = pd.DataFrame(Stock_dict)
# 行业数据统计
Output_dicy = {}
Output_dicy['industry'] = []
Output_dicy['Num'] = []
Output_dicy['Nov14'] = []

for ind,tks in Ind_tks_dic.items() :
    for table in Stock_Data.keys() : 
        if not table in Output_dicy.keys() : 
            Output_dicy[table] = []
        sub_Industry = Stock_Data[table][Stock_Data[table]['ticker'].isin(tks)]      
         # 成交量前三
        bigstk = sub_Industry.sort(columns='turnoverValue',ascending=False)['ticker'][0:3].tolist()
        # 行业指数收益
        if not sub_Industry['marketValue'].sum() == 0 : 
            rtn_Industry = (sub_Industry['income']*sub_Industry['marketValue']).sum()/sub_Industry['marketValue'].sum()         
            Output_dicy[table].append(rtn_Industry)
            if table == '20141031' :   
                Output_dicy['Nov14'].append(map(lambda x:tk_nm_dic['20141031'][x],bigstk))
              
    if not sub_Industry['marketValue'].sum() == 0 :          
        #最新行业成分数量     
        Output_dicy['Num'].append(len(sub_Industry))
        Output_dicy['industry'].append(ind)       

Output_table = pd.DataFrame(Output_dicy)

去年十一月疯长的大盘

# 统计并显示
Out_put = Output_table.loc[:,['industry','Num','20101031','20111031','20121031','20131031','20141031','Nov14']]
Out_put.columns = [u'行业名称',u'该行业成分股数目(15年)',u'2010年十一月',u'2011年十一月',u'2012年十一月',u'2013年十一月',u'2014年十一月',u'2014年板块成交量前三']
Out_put[u'平均涨幅'] = (Out_put[u'2010年十一月']+Out_put[u'2011年十一月']+Out_put[u'2012年十一月']+Out_put[u'2013年十一月']+Out_put[u'2014年十一月']) / 5
print u'一共有%d个申万二级行业'%len(Out_put),u' : '
Out_put.sort(u'2014年十一月' , ascending = False).head(20)
一共有208个申万二级行业  : 
行业名称 该行业成分股数目(15年) 2010年十一月 2011年十一月 2012年十一月 2013年十一月 2014年十一月 2014年板块成交量前三 平均涨幅
97 资本市场服务 18 -0.141082 -0.152839 -0.133307 0.098754 0.511463 [中信证券, 海通证券, 兴业证券] 0.036598
22 证券 20 -0.142078 -0.150951 -0.129955 0.094950 0.493749 [中信证券, 海通证券, 兴业证券] 0.033143
107 综合金融 21 -0.139421 -0.148480 -0.132800 0.095897 0.477825 [中信证券, 海通证券, 兴业证券] 0.030604
2 航空运输 6 -0.179507 -0.123943 -0.094819 0.015406 0.406586 [海南航空, 东方航空, 中信海直] 0.004744
149 航空运输业 10 -0.173271 -0.107966 -0.082920 0.015486 0.343224 [海南航空, 东方航空, 中信海直] -0.001089
38 保险业 3 -0.095615 -0.017941 -0.035695 0.154288 0.323310 [中国平安, 中国太保, 中国人寿] 0.065669
153 保险 4 -0.095476 -0.018500 -0.035806 0.154006 0.323234 [中国平安, 中国太保, 中国人寿] 0.065492
92 房屋建筑业 1 0.000000 0.000000 -0.127193 0.202055 0.316129 [高新发展] 0.078198
112 高速公路 23 -0.108908 -0.088902 -0.073154 0.052344 0.272050 [广发证券, 厦门港务, 五洲交通] 0.010686
193 石油加工、炼焦和核燃料加工业 18 0.007286 -0.034520 -0.127721 0.005377 0.258827 [陕西黑猫, 上海石化, *ST华锦] 0.021850
122 建筑安装业 1 -0.113664 -0.006221 -0.139037 0.020833 0.213740 [中关村] -0.004870
139 基础建设 22 -0.037736 -0.088644 0.009290 0.011860 0.212001 [中国中铁, 中国铁建, 中国交建] 0.021354
202 农、林、牧、渔服务业 1 -0.013893 0.032037 -0.106501 0.055081 0.210865 [丰乐种业] 0.035518
113 房屋建设 4 -0.046656 -0.087118 0.006878 0.009602 0.202862 [中国建筑, 上海建工, 宁波建工] 0.017114
176 园区开发 18 -0.042658 -0.077632 -0.073093 -0.033278 0.200555 [陆家嘴, 外高桥, 金融街] -0.005221
39 租赁业 1 -0.149817 0.011525 -0.106517 0.043152 0.200312 [渤海租赁] -0.000269
82 土木工程建筑业 45 -0.028200 -0.077634 -0.003929 0.004428 0.181418 [中国建筑, 中国中铁, 中国铁建] 0.015217
194 货币金融服务 16 -0.060532 -0.046490 0.017593 0.012884 0.181281 [浦发银行, 兴业银行, 民生银行] 0.020947
101 银行 16 -0.060532 -0.046490 0.017593 0.012884 0.181281 [浦发银行, 兴业银行, 民生银行] 0.020947
67 燃气生产和供应业 9 -0.097077 0.016135 -0.038805 0.005440 0.178853 [大众公用, 重庆燃气, 申能股份] 0.012909

五年间十一月平均涨幅

Out_put.sort(u'平均涨幅' , ascending = False).head(20)
行业名称 该行业成分股数目(15年) 2010年十一月 2011年十一月 2012年十一月 2013年十一月 2014年十一月 2014年板块成交量前三 平均涨幅
92 房屋建筑业 1 0.000000 0.000000 -0.127193 0.202055 0.316129 [高新发展] 0.078198
38 保险业 3 -0.095615 -0.017941 -0.035695 0.154288 0.323310 [中国平安, 中国太保, 中国人寿] 0.065669
153 保险 4 -0.095476 -0.018500 -0.035806 0.154006 0.323234 [中国平安, 中国太保, 中国人寿] 0.065492
35 林业 5 0.010244 0.117180 0.028619 0.012805 0.085120 [平潭发展, 永安林业, 吉林森工] 0.050794
200 运输设备 7 0.116078 -0.056020 0.095749 0.071869 0.008633 [晋西车轴, 北方创业, 康尼机电] 0.047262
97 资本市场服务 18 -0.141082 -0.152839 -0.133307 0.098754 0.511463 [中信证券, 海通证券, 兴业证券] 0.036598
202 农、林、牧、渔服务业 1 -0.013893 0.032037 -0.106501 0.055081 0.210865 [丰乐种业] 0.035518
22 证券 20 -0.142078 -0.150951 -0.129955 0.094950 0.493749 [中信证券, 海通证券, 兴业证券] 0.033143
107 综合金融 21 -0.139421 -0.148480 -0.132800 0.095897 0.477825 [中信证券, 海通证券, 兴业证券] 0.030604
123 铁路运输业 3 -0.074811 -0.032704 0.033269 0.058432 0.158774 [大秦铁路, 广深铁路, 铁龙物流] 0.028592
111 餐饮业 4 0.116088 0.030976 -0.115720 0.094488 0.002694 [*ST云网, 西安饮食, 全聚德] 0.025705
188 互联网和相关服务 12 0.063492 0.059126 -0.123481 0.001113 0.127137 [东方财富, 鹏博士, 海虹控股] 0.025477
182 电气自动化设备 30 0.181047 0.021313 -0.121661 0.000477 0.045836 [国电南瑞, 许继电气, 川仪股份] 0.025402
20 专业技术服务业 9 0.173828 -0.040446 -0.119783 0.046313 0.057355 [中材节能, 设计股份, 三联虹普] 0.023453
193 石油加工、炼焦和核燃料加工业 18 0.007286 -0.034520 -0.127721 0.005377 0.258827 [陕西黑猫, 上海石化, *ST华锦] 0.021850
4 铁路运输 3 -0.074811 -0.032704 0.028185 0.057472 0.130967 [大秦铁路, 广深铁路, 铁龙物流] 0.021822
139 基础建设 22 -0.037736 -0.088644 0.009290 0.011860 0.212001 [中国中铁, 中国铁建, 中国交建] 0.021354
194 货币金融服务 16 -0.060532 -0.046490 0.017593 0.012884 0.181281 [浦发银行, 兴业银行, 民生银行] 0.020947
101 银行 16 -0.060532 -0.046490 0.017593 0.012884 0.181281 [浦发银行, 兴业银行, 民生银行] 0.020947
44 食品制造业 22 0.150009 0.017352 -0.080203 -0.045608 0.059697 [伊利股份, 光明乳业, 花园生物] 0.020249