请 [注册] 或 [登录]  | 返回主站

量化交易吧 /  数理科学 帖子:3365785 新帖:17

获取股票所属的板块,概念,指数

我是一个土豆发表于:5 月 9 日 18:46回复(1)

有时我们想获取股票所属的板块,概念,指数,但目前还很不方便。所以写了一个函数,方便大家使用。

由于个人码力有限,函数效率不是很高,另外未经严格测试,难免有bug的可能,请多指教咯

获取股票所属的板块,概念,指数¶

输入:¶

stock_list 股票代码列表,数据类型为list date 日期,数据类型为xxxx-xx-xx格式的字符串

输出:¶

一个字典 key为股票代码 value为list,list中有三个list,依次是所属板块、所属概念、所属指数

已知问题:¶

'000851.XSHG','000923.XSHG'这两个指数不在检查范围内,即如果股票属于这两个指数,则不会返回这两个指数的代码

样例:¶

输入:

stock_list=['601313.XSHG','300699.XSHE']
date='2017-09-26'
get_stock_home(stock_list,date)

输出:

{'300699.XSHE': [['C28', 'HY002', 'HY570', '801030', '801032', '850344'],
  ['GN189'],
  ['000902.XSHG',
   '000938.XSHG',
   '399102.XSHE',
   '399106.XSHE',
   '399107.XSHE',
   '399938.XSHE']],
 '601313.XSHG': [['C34', 'HY003', 'HY427', '801890', '801074', '850728'],
  ['GN119', 'GN193'],
  ['000001.XSHG',
   '000002.XSHG',
   '000004.XSHG',
   '000017.XSHG',
   '000020.XSHG',
   '000090.XSHG',
   '000153.XSHG',
   '000902.XSHG',
   '000938.XSHG',
   '000985.XSHG',
   '000988.XSHG',
   '399303.XSHE',
   '399317.XSHE',
   '399410.XSHE',
   '399938.XSHE']]}
def get_stock_home(stock_list,date):
    import pandas as pd
    import requests
    from bs4 import BeautifulSoup
    # 获取指数列表
    def get_index_list():
        """
        获取指数列表, 数据见:https://www.joinquant.com/indexData
        """
        r  = requests.get(r'https://www.joinquant.com/indexData')
        data = r.content.decode("utf-8")
        soup = BeautifulSoup(data, "lxml")

        table = soup.find_all('table')[0]

        result = []
        for row in table.find_all('tr'):
            result.append([x.text for x in row.find_all('td')])

        result = pd.DataFrame(result[1:], columns=['index_code', 'index_name', 'start_date', 'short_name'])
        result['start_date'] = pd.to_datetime(result['start_date'])

        return result
    #证监会行业
    HY_ZJH = ['A01','A02','A03','A04','A05','B06','B07','B08','B09','B11','C13','C14','C15','C17','C18','C19','C20','C21','C22','C23','C24','C25','C26','C27','C28','C29','C30','C31','C32','C33','C34','C35','C36','C37','C38','C39','C40','C41','C42','D44','D45','D46','E47','E48','E50','F51','F52','G53','G54','G55','G56','G58','G59','H61','H62','I63','I64','I65','J66','J67','J68','J69','K70','L71','L72','M73','M74','N77','N78','P82','Q83','R85','R86','R87','S90']
    #聚宽一级行业
    HY_ZY1 = ['HY001','HY002','HY003','HY004','HY005','HY006','HY007','HY008','HY009','HY010','HY011']
    #聚宽二级行业
    HY_ZY2 = ['HY401','HY402','HY403','HY404','HY405','HY406','HY407','HY408','HY409','HY410','HY411','HY412','HY413','HY414','HY415','HY416','HY417','HY418','HY419','HY420','HY421','HY422','HY423','HY424','HY425','HY426','HY427','HY428','HY429','HY432','HY433','HY434','HY435','HY436','HY437','HY438','HY439','HY440','HY441','HY442','HY443','HY444','HY445','HY446','HY447','HY448','HY449','HY450','HY451','HY452','HY453','HY454','HY455','HY457','HY458','HY459','HY460','HY461','HY462','HY463','HY464','HY465','HY466','HY467','HY468','HY469','HY470','HY471','HY472','HY473','HY474','HY476','HY477','HY478','HY479','HY480','HY481','HY483','HY484','HY485','HY486','HY487','HY488','HY489','HY491','HY492','HY493','HY494','HY496','HY497','HY500','HY501','HY504','HY505','HY506','HY509','HY510','HY511','HY512','HY513','HY514','HY515','HY516','HY517','HY518','HY519','HY520','HY521','HY523','HY524','HY525','HY526','HY527','HY528','HY529','HY530','HY531','HY570','HY571','HY572','HY573','HY574','HY576','HY578','HY579','HY587','HY588','HY591','HY593','HY595','HY596','HY597','HY598','HY601']
    #申万一级行业
    SW1 = ['801010','801020','801030','801040','801050','801080','801110','801120','801130','801140','801150','801160','801170','801180','801200','801210','801230','801710','801720','801730','801740','801750','801760','801770','801780','801790','801880','801890']
    #申万二级行业
    SW2 = ['801011','801012','801013','801014','801015','801016','801017','801018','801021','801022','801023','801024','801032','801033','801034','801035','801036','801037','801041','801051','801053','801054','801055','801072','801073','801074','801075','801076','801081','801082','801083','801084','801085','801092','801093','801094','801101','801102','801111','801112','801123','801131','801132','801141','801142','801143','801144','801151','801152','801153','801154','801155','801156','801161','801162','801163','801164','801171','801172','801173','801174','801175','801176','801177','801178','801181','801182','801191','801192','801193','801194','801202','801203','801204','801205','801211','801212','801213','801214','801215','801222','801223','801231','801711','801712','801713','801721','801722','801723','801724','801725','801731','801732','801733','801734','801741','801742','801743','801744','801751','801752','801761','801881']
    #申万三级行业
    SW3 = ['850111','850112','850113','850121','850122','850131','850141','850151','850152','850154','850161','850171','850181','850211','850221','850222','850231','850241','850242','850311','850313','850321','850322','850323','850324','850331','850332','850333','850334','850335','850336','850337','850338','850339','850341','850342','850343','850344','850345','850351','850352','850353','850361','850362','850363','850372','850373','850381','850382','850383','850411','850412','850521','850522','850523','850531','850541','850542','850543','850544','850551','850552','850553','850611','850612','850614','850615','850616','850623','850711','850712','850713','850714','850715','850716','850721','850722','850723','850724','850725','850726','850727','850728','850729','850731','850741','850751','850811','850812','850813','850822','850823','850831','850832','850833','850841','850851','850852','850911','850912','850913','850921','850935','850936','850941','851012','851013','851014','851021','851111','851112','851113','851114','851115','851121','851122','851231','851232','851233','851234','851235','851236','851241','851242','851243','851244','851311','851312','851313','851314','851315','851316','851322','851323','851324','851325','851326','851327','851411','851421','851432','851433','851434','851435','851441','851511','851512','851521','851531','851541','851551','851561','851611','851612','851613','851614','851615','851621','851631','851641','851711','851721','851731','851741','851751','851761','851771','851781','851811','851821','851911','851921','851931','851941','852021','852031','852032','852033','852041','852051','852052','852111','852112','852121','852131','852141','852151','852211','852221','852222','852223','852224','852225','852226','852241','852242','852243','852244','852311','857221','857231','857232','857233','857234','857235','857241','857242','857243','857244','857251','857321','857322','857323','857331','857332','857333','857334','857335','857336','857341','857342','857343','857344','857411','857421','857431','858811']
    #概念板块
    GN = ['GN001','GN028','GN030','GN031','GN032','GN034','GN035','GN036','GN039','GN040','GN041','GN045','GN046','GN050','GN057','GN062','GN069','GN074','GN075','GN076','GN077','GN079','GN080','GN081','GN086','GN087','GN088','GN089','GN090','GN091','GN092','GN093','GN096','GN098','GN099','GN100','GN101','GN103','GN104','GN106','GN107','GN109','GN110','GN111','GN112','GN113','GN114','GN115','GN116','GN119','GN121','GN123','GN124','GN125','GN126','GN127','GN128','GN129','GN130','GN131','GN132','GN133','GN134','GN135','GN136','GN137','GN138','GN139','GN140','GN141','GN142','GN144','GN145','GN146','GN148','GN149','GN151','GN152','GN153','GN154','GN155','GN156','GN157','GN158','GN159','GN160','GN161','GN162','GN163','GN164','GN165','GN166','GN167','GN168','GN169','GN170','GN171','GN172','GN173','GN174','GN175','GN176','GN177','GN178','GN179','GN180','GN181','GN182','GN183','GN184','GN185','GN186','GN187','GN188','GN189','GN190','GN191','GN192','GN193','GN194','GN195','GN196','GN197','GN198','GN199','GN200','GN201','GN202','GN203','GN204','GN205','GN206','GN207','GN208','GN209','GN210','GN211','GN212','GN213','GN214','GN215','GN216','GN217','GN218','GN219','GN220','GN221','GN222','GN223','GN224','GN225','GN226','GN227','GN228','GN229','GN230']
    #所有行业
    industry=HY_ZJH + HY_ZY1 + HY_ZY2 + SW1 + SW2 + SW3
    # 指数列表
    index_code_list=list(get_index_list()['index_code'].values)
    
    r={}
    for stock in stock_list :
        r1=[]
        r2=[]
        r3=[]
        for i in industry:
            t=get_industry_stocks(i,date)
            if stock in t:
                r1+=[i]
        for i in GN:
            t=get_concept_stocks(i,date)
            if stock in t:
                r2+=[i]
        for i in index_code_list:
            if i == '000851.XSHG' or i == '000923.XSHG':
                continue
            t=get_index_stocks(i,date)
            if stock in t:
                r3+=[i]
        r[stock]=[r1,r2,r3]
    return r
stock_list=['601313.XSHG','300699.XSHE']
date='2017-09-26'
sth=get_stock_home(stock_list,date)
# 所属行业
sth['601313.XSHG'][0]
['C34', 'HY003', 'HY427', '801890', '801074', '850728']
# 所属概念
sth['601313.XSHG'][1]
['GN119', 'GN193']
# 所属指数
sth['601313.XSHG'][2]
[u'000001.XSHG',
 u'000002.XSHG',
 u'000004.XSHG',
 u'000017.XSHG',
 u'000020.XSHG',
 u'000090.XSHG',
 u'000153.XSHG',
 u'000891.XSHG',
 u'000902.XSHG',
 u'000938.XSHG',
 u'000985.XSHG',
 u'000988.XSHG',
 u'399303.XSHE',
 u'399317.XSHE',
 u'399410.XSHE',
 u'399902.XSHE',
 u'399938.XSHE',
 u'399985.XSHE']

全部回复

0/140

量化课程

    移动端课程