gjy499 2021-09-01 02:39 采纳率: 78.6%
浏览 142
已结题

以每日收益率为标准计算股票之间相关性

用tushare包计算以hs300每日收益率为标准计算其与其他三支股票的相关性,并以热力图的形式可视化出来,探究哪支股票与hs300有较大的相关性。下图为hs300和其他三只股票的每日收益率。(附上code,谢谢)
img

img

  • 写回答

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()
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 9月1日
  • 已采纳回答 9月1日
  • 创建了问题 9月1日

悬赏问题

  • ¥50 求解vmware的网络模式问题
  • ¥24 EFS加密后,在同一台电脑解密出错,证书界面找不到对应指纹的证书,未备份证书,求在原电脑解密的方法,可行即采纳
  • ¥15 springboot 3.0 实现Security 6.x版本集成
  • ¥15 PHP-8.1 镜像无法用dockerfile里的CMD命令启动 只能进入容器启动,如何解决?(操作系统-ubuntu)
  • ¥30 请帮我解决一下下面六个代码
  • ¥15 关于资源监视工具的e-care有知道的嘛
  • ¥35 MIMO天线稀疏阵列排布问题
  • ¥60 用visual studio编写程序,利用间接平差求解水准网
  • ¥15 Llama如何调用shell或者Python
  • ¥20 谁能帮我挨个解读这个php语言编的代码什么意思?