繁簡切換您正在訪問的是FX168財經網,本網站所提供的內容及信息均遵守中華人民共和國香港特別行政區當地法律法規。

FX168财经网>人物频道>帖子

共享函数 | 常用数据获取及计算系列

作者/fx16820000 2019-05-09 21:52 0 来源: FX168财经网人物频道

对于常见但是获取比较不太方便的数据我们将会写成一系列共享函数方便大家直接复制使用。
本系列将持续更新,标题为 【共享函数】



包含的函数:


换手率
量比
股票股息率
所有商品指数,主力合约,品种代号等
期货合约的基本信息(合约乘数、商品报价的计数单位、最小变动单位)

实时(分钟级别)换手率¶

非实时的换手率数据可以直接通过 val uation 表拿到,传送门:
https://www.joinquant.com/help/api/help?name=Stock#市值数据

def get_turnover_ratio(stocks,now_time):'''传入股票池,时间,返回实时换手率'''if isinstance(stocks, str):stocks = [stocks]if isinstance(now_time, str):now_time =datetime.datetime.strptime(now_time,'%Y-%m-%d %H:%M:%S')data = get_price(stocks,fields='volume',end_date=now_time,start_date=now_time.date(),frequency ='1m' ).volume.sum()valuation_data = get_fundamentals(query(         #财务数据可以一天获取一次,自行更改valuation.code,valuation.circulating_cap    ).filter(valuation.code.in_(stocks)),date=now_time).set_index('code')return data/valuation_data.iloc[:,0]/100get_turnover_ratio(['000001.XSHE','000002.XSHE'],datetime.datetime.now())
/opt/conda/lib/python3.6/site-packages/jqresearch/api.py:86: FutureWarning: 
Panel is deprecated and will be removed in a future version.
The recommended way to represent these types of 3-dimensional data are with a MultiIndex on a DataFrame, via the Panel.to_frame() method
Alternatively, you can use the xarray package http://xarray.pydata.org/en/stable/.
Pandas provides a `.to_xarray()` method to help automate this conversion.

  pre_factor_ref_date=_get_today())
000001.XSHE    0.844864
000002.XSHE    0.877389
dtype: float64
# 区间换手率from jqdata import *def shuttle_turnover_ratio(code_list,end_date,start_date=None,day=None):'''start_date和day 二选一 , 选取day参数时代表day个交易日的区间换手率'''if not day:day = len(get_trade_days(start_date,end_date))if isinstance(code_list,str):code_list=[code_list]q = query(valuation.turnover_ratio).filter(valuation.code.in_(code_list))data =  get_fundamentals_continuously(q,end_date=end_date,count=day).turnover_ratioreturn data.sum()shuttle_turnover_ratio(['000001.XSHE','000002.XSHE'],'2018-11-13',day=10)
code
000001.XSHE    7.0689
000002.XSHE    5.1873
dtype: float64

量比¶

import pandas as pddef get_v_ratio(security_list,time):'''计算某个时间点股票的量比,    输入:股票池/股票,时间(datetime)    返回:截至当天某一时间点的量比'''if isinstance(security_list,str):security_list = [security_list]d = pd.Series()time2= time-datetime.timedelta(days=1)start_time = datetime.datetime(time.year,time.month,time.day,9,30)for security in security_list:ma5 = get_price(security,end_date=time2,frequency='5d',skip_paused=True,fields='volume',count=1,fq=None).volume/1200n_ma = get_price(security,end_date=time,start_date =start_time ,skip_paused=True,fields='volume',  frequency='1m').volume.mean()d[security]=float(n_ma/ma5)return dsecurity_list = ['600016.XSHG','601166.XSHG','000001.XSHE']time = datetime.datetime(2018,9,27,15,30)get_v_ratio(security_list,time)
600016.XSHG    0.810266
601166.XSHG    0.869788
000001.XSHE    0.740555
dtype: float64

股票股息率¶

股息率(DividendRatio)=公司派现合计/股票市值。其中,公司派现合计是指从年初到该报告期的派现合计累计(整个公司的派现合计)
指数股息率传送门:  https://www.joinquant.com/post/16656

from jqdata import *def DividendRatio(security_list,end_date,count=1):'''查询股息率(日更新)      输入:股票池,截止日期,获取数量    输出:panel结构,单位:1'''trade_days = get_trade_days(end_date=end_date,count = count)security_list.sort()secu_list = [x[:6] for x in security_list]code_df = jy.run_query(query( jy.SecuMain.InnerCode,jy.SecuMain.SecuCode,#     jy.SecuMain.ChiName,jy.SecuMain.CompanyCode).filter(jy.SecuMain.SecuCode.in_(secu_list),jy.SecuMain.SecuCategory==1).order_by(jy.SecuMain.SecuCode))code_df['code'] = security_listdf = jy.run_query(query(#         jy.LC_DIndicesForValuation    #得到整表jy.LC_DIndicesForValuation.InnerCode,jy.LC_DIndicesForValuation.TradingDay, jy.LC_DIndicesForValuation.DividendRatio,).filter(jy.LC_DIndicesForValuation.InnerCode.in_(code_df.InnerCode),jy.LC_DIndicesForValuation.TradingDay.in_(trade_days)))f_df = df.merge(code_df,on='InnerCode').set_index(['TradingDay','code']).drop(['InnerCode','SecuCode'],axis=1)#     panel = f_df.to_panel()return f_df['DividendRatio'].unstack()securitys =['000001.XSHE','000002.XSHE']date='2019-02-22'DividendRatio(securitys,date,count=5)

.dataframe thead tr:only-child th {        text-align: right;    }    .dataframe thead th {        text-align: left;    }    .dataframe tbody tr th {        vertical-align: top;    }

code000001.XSHE000002.XSHE
TradingDay

2019-02-180.0119720.033088
2019-02-190.0120670.033296
2019-02-200.0119190.032573
2019-02-210.0119720.033395
2019-02-220.0117850.033370

获取所有商品指数,主力合约,品种代号等¶

df = get_all_securities(types=['futures'])                        #获取期货合约,指定date可以过滤退市合约# dominant_and_idnex = df[df.end_date==datetime.date(2030,1,1)]   #商品指数和主力合约dominant_future = df[df.index.str.contains('9999')]               #所有品种的主力合约index_future = df[df.index.str.contains('8888')]                  #所有品种的指数代码code_name = index_future.index.str.slice(start=0,stop=-9).tolist() #获取各个品种代号,使用get_dominant_future时会用到

获取期货合约的基本信息(合约乘数、商品报价的计数单位、最小变动单位)¶

"""获取期货合约的基本信息(合约乘数、商品报价的计数单位、最小变动单位)本函数由丹阳同学提供数据来源:聚源数据Fut_ContractMain表,https://www.joinquant.com/help/data/data?name=jy#nodeId=23参考帖子:http://bbs.tb18.net/thread-80004-1-1.html输入:合约代码(例如:SC1901.XINE)返回:dict格式合约乘数、商品报价的计数单位、最小变动单位         {'ContractUnit': 1000, 'MinPoint': 0.1, 'PriceScale': 0.1}"""# lru缓存可以不要,加上后查询相同的合约可以避免重复数据库请求from fastcache import clru_cache as lru_cache@lru_cache(maxsize=128)def future_basic_info(future):from jqdata import jyfrom numpy import nanimport reif "9999" in future or "8888" in future:match = re.match(r"(?P<underlying_symbol>[A-Z]{1,})", future)if not match:raise ValueError("未知期货标的:{}".format(future))else:future = get_dominant_future(match.groupdict()["underlying_symbol"])q = query(jy.Fut_ContractMain).filter(jy.Fut_ContractMain.ContractCode == future.split(".")[0])result = jy.run_query(query_object=q).to_dict("record")if result:result = result.pop()min_point = re.match("(?P<value>^[0-9]+([.]{1}[0-9]+){0,1})", result["LittlestChangeUnit"]).groupdict(nan)["value"]return {"ContractUnit": result["CMValue"],   "PriceScale": float(min_point)/float(result["CMValue"]),   "MinPoint": float(min_point)}else:return {"ContractUnit": nan,"PriceScale": nan,"MinPoint": nan}future_basic_info('CU9999.XSGE')
{'ContractUnit': 5, 'MinPoint': 10.0, 'PriceScale': 2.0}
 
分享到:
举报财经168客户端下载

全部回复

0/140

投稿 您想发表你的观点和看法?

更多人气分析师

  • 张亦巧

    人气2200文章4145粉丝45

    暂无个人简介信息

  • 王启蒙现货黄金

    人气304文章3275粉丝8

    本人做分析师以来,并专注于贵金属投资市场,尤其是在现货黄金...

  • 指导老师

    人气1864文章4423粉丝52

    暂无个人简介信息

  • 李冉晴

    人气2320文章3821粉丝34

    李冉晴,专业现贷实盘分析师。

  • 梁孟梵

    人气2176文章3177粉丝39

    qq:2294906466 了解群指导添加微信mfmacd

  • 张迎妤

    人气1896文章3305粉丝34

    个人专注于行情技术分析,消息面解读剖析,给予您第一时间方向...

  • 金泰铬J

    人气2328文章3925粉丝51

    投资问答解咨询金泰铬V/信tgtg67即可获取每日的实时资讯、行情...

  • 金算盘

    人气2696文章7761粉丝125

    高级分析师,混过名校,厮杀于股市和期货、证券市场多年,专注...

  • 金帝财神

    人气4760文章8329粉丝119

    本文由资深分析师金帝财神微信:934295330,指导黄金,白银,...

FX168财经

FX168财经学院

FX168财经

FX168北美