# tushare实战分析上证综指与美债收益率的关系
提示:如果还不知道tushare的小伙伴,我悄悄告诉你们tushare网址
数据获取
目标数据: 2000-2021美国国债收益率与利率 、 2000-2021上证综指的历史数据
获取2000-2021美国国债收益率与利率的数据
书接上文, 导入上次获取的2000-2021美国国债收益率与利率的数据;
如果没看过我上篇文章的请快去 Tushare实战分析美国国债收益率与利率的关系
先将每日数据转换为月度数据
代码如下:
import pandas as pd
#%% 数据处理
data = pd.read_csv('2000-2021美债收益率及货币量变化.csv')
# 将每日的数据调整成每月数据
def transfer(data):
for i in range(len(data)):
data.iloc[i, 0] = data.iloc[i, 0][0:6]
return data.groupby('date').mean()
data_month = transfer(data)
# 缺失值处理
sum(data_month.m1.isna()==True) #查看缺失值个数
sum(data_month.m3.isna()==True) #查看缺失值个数
sum(data_month.m6.isna()==True) #查看缺失值个数
sum(data_month.y10.isna()==True) #查看缺失值个数
sum(data_month.y20.isna()==True) #查看缺失值个数
sum(data_month.y30.isna()==True) #查看缺失值个数
data_month.fillna(method='bfill', inplace=True) #把最邻近填充进去
data_month.to_csv('2000-2021美债收益率及货币量变化(月).csv')
获取2000-2021上证综指的历史数据
# 导入tushare
import tushare as ts
# 初始化pro接口
pro = ts.pro_api('你的神秘代码')
# 拉取数据 000001.SH 上证综指
df = pro.index_monthly(**{
"ts_code": "000001.SH",
"trade_date": "",
"start_date": 20000101,
"end_date": 20210101,
"limit": "",
"offset": ""
}, fields=[
"ts_code",
"trade_date",
"close",
"open",
"high",
"low",
"pre_close",
"change",
"pct_chg",
"vol",
"amount"
])
注意:
你的神秘代码在tushare的个人主页 -- 接口token中获取
将两个数据集依据时间合并
注意事项
- 在合并的时候是横向合并, 以时间为index, 将两个数据表横向拼接;
axis=1
- 要保持index不变, 所以要将两个数据表的date(美债是date, 上证是trade_date)字段的类型控制相同
话不多说, 上代码!!!
# 导入2021美债收益率及货币量变化数据
import pandas as pd
american_bond = pd.read_csv('2000-2021美债收益率及货币量变化(月).csv')
# df数据是上面带下来的
df['trade_date'] = df['trade_date'].apply(lambda x: x[0:6])
df['trade_date'] = df['trade_date'].astype(int)
df = df[::-1]
df.to_csv('2000-2021上证综指变化(月).csv')
df.set_index('trade_date', inplace=True)
american_bond.set_index('date', inplace=True)
data = pd.concat([df, american_bond], axis=1)
绘图查看上证综指变化率与美债收益率的关系
将上证综指的指数变换与美债收益率的变化画在同一幅图中
注意
- 不同y轴刻度画在同一幅图中, 关键是twinx()
- 设置年份的x轴, 关键是xticks
话不多说, 上代码!!!
#%% 绘图查看上证综指变化率与美债收益率的关系
import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei']
plt.rcParams['axes.unicode_minus'] = False
fig, ax1 = plt.subplots()
month = [12*i for i in range(21)]
year = [i for i in range(2000, 2021)]
plt.xticks(month, year, rotation=45)
ax1.plot(range(len(data)), data.close, '-r', label='上证综指')
ax1.set_xlabel("年份")
ax1.set_ylabel("上证综指")
ax2 = ax1.twinx()
ax2.plot(range(len(data)), data.y30, 'y', label='美国国债收益率')
ax2.set_ylabel("美国国债收益率")
fig.legend()
plt.show()
结果如下:
绘图查看上证综指变化率与利率的关系
基本同上;
fig, ax1 = plt.subplots()
month = [12*i for i in range(21)]
year = [i for i in range(2000, 2021)]
plt.xticks(month, year, rotation=45)
ax1.plot(range(len(data)), data.close, '-r', label='上证综指')
ax1.set_xlabel("年份")
ax1.set_ylabel("上证综指")
ax2 = ax1.twinx()
ax2.plot(range(len(data)), data.m6, 'y', label='利率')
ax2.set_ylabel("利率")
fig.legend()
plt.show()
结果如下:
结果分析
从上图可以看出股债市场基本是反向变动. 所以给我们的投资组合中的股债对冲形成了理论依据;
从上图可以看出利率变动与股市变动基本是同向变动, 而股票市场的变动相对于利率变动则要滞后一些, 从图中预期上证综指在21年后会有一个不小的涨幅