用tushare包计算以hs300每日收益率为标准计算其与其他三支股票的相关性,并以热力图的形式可视化出来,探究哪支股票与hs300有较大的相关性。下图为hs300和其他三只股票的每日收益率。(附上code,谢谢)
以每日收益率为标准计算股票之间相关性
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- CSDN专家-HGJ 2021-09-01 17:54关注
使用pandas中的corr函数计算hs300与每只股票的相关系数。参考代码:
import matplotlib.pyplot as plt import tushare as ts import pandas as pd from concurrent.futures import ThreadPoolExecutor import seaborn as sns def get_data(tick): return ts.get_k_data(tick, start='2020-09-01', end='2021-06-30') ticks = ['hs300','002254', '002224', '000507'] ndf=pd.DataFrame() with ThreadPoolExecutor(max_workers=3) as ex: res=ex.map(get_data,ticks) for i,df in enumerate(res): #df.to_excel(f'stock_{ticks[i]}.xlsx',index=False) x = df['date'] y = (df['close']-df['close'].shift(1))/df['close'].shift(1) ys=y.cumsum() ndf[ticks[i]]=ys ndf=ndf.fillna(method='ffill').fillna(method='bfill') corr=ndf.corr() print(corr) corrs={} for tick in ndf.columns[1:]: cor=ndf[['hs300',tick]].corr() corrs[f'hs300&{tick}']=cor.loc['hs300',tick] print(corrs) sns.heatmap(corr, square=True, annot=True) plt.show()
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 微信小程序协议怎么写
- ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
- ¥20 怎么用dlib库的算法识别小麦病虫害
- ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
- ¥15 java写代码遇到问题,求帮助
- ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
- ¥15 有了解d3和topogram.js库的吗?有偿请教
- ¥100 任意维数的K均值聚类
- ¥15 stamps做sbas-insar,时序沉降图怎么画
- ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看