我有一个熊猫df,如下所示:
>>> df
sales net_pft sales_gr net_pft_gr
STK_ID RPT_Date
600809 20120331 22.1401 4.9253 0.1824 -0.0268
20120630 38.1565 7.8684 0.3181 0.1947
20120930 52.5098 12.4338 0.4735 0.7573
20121231 64.7876 13.2731 0.4435 0.7005
20130331 27.9517 7.5182 0.2625 0.5264
20130630 40.6460 9.8572 0.0652 0.2528
20130930 53.0501 11.8605 0.0103 -0.0461
然后df[['sales','net_pft']].unstack('STK_ID').plot(kind='bar', use_index=True)
创建条形图。
并df[['sales_gr','net_pft_gr']].plot(kind='line', use_index=True)
创建折线图:
现在我想使用 twinx() 将它们放在两个 y 轴的图表中。
import matplotlib.pyplot as plt
fig = plt.figure()
ax = df[['sales','net_pft']].unstack('STK_ID').plot(kind='bar', use_index=True)
ax2 = ax.twinx()
ax2.plot(df[['sales_gr','net_pft_gr']].values, linestyle='-', marker='o', linewidth=2.0)
结果是这样的:
我的问题是:
- 如何移动线以与相同 x-tickers 的条对齐?
- 如何让左右 y_axis 代码在同一行对齐?