我有一个这样的数据框
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,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40852958/