我有一个这样的数据框

from datetime import date
import random

start_date = date.today().replace(day=1, month=1).toordinal()
end_date = date.today().toordinal()

df=pd.DataFrame.from_dict({'dates':[ date.fromordinal(random.randint(start_date, end_date)) for i in xrange(10) ]
                        ,'n':np.random.randint(0,100,10)})
df.index=df['dates']; del df['dates']
df.sort_index(inplace=True)

其中产生
             n
dates
2016-01-24   0
2016-02-26  98
2016-03-04  68
2016-03-26  45
2016-05-03  89
2016-05-09  83
2016-05-11  58
2016-07-29  53
2016-09-18  79
2016-10-20  57

我想绘制它并有一个 2 月和 3 月的 axvspan。由于我的日期是随机的,我该如何选择那 2 个月并使用 axvspan

我的绘图代码很简单
ax=df.plot()

最佳答案

这是一个例子。如果日期跨越几年,则必须对其进行改进。您也可以查看this question 的答案,因为原理完全相同。

ax = df.plot()
# Getting the boundaries for dates in feb and march
period = df[(df.index.month > 1) & (df.index.month < 3)].index
# Highlighting
ax.axvspan(min(period) - MonthBegin(), max(period) + MonthEnd(),
           facecolor='g', edgecolor='none', alpha=.2)

Pandas 图 axvspan-LMLPHP

关于 Pandas 图 axvspan,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40852958/

10-12 17:39