【发布时间】:2016-12-31 06:22:46
【问题描述】:
我想每月绘制数据并每年显示一次年份标签。 这是数据:
timedates = ['2013-01-01', '2013-02-01', '2013-03-01', '2013-04-01', '2013-05-01', '2013-06-01', '2013-07-01',
'2013-08-01', '2013-09-01', '2013-10-01', '2013-11-01', '2013-12-01', '2014-01-01', '2014-02-01',
'2014-03-01', '2014-04-01', '2014-05-01', '2014-06-01', '2014-07-01', '2014-08-01', '2014-09-01',
'2014-10-01', '2014-11-01', '2014-12-01']
timedates = pd.to_datetime(timedates)
amount = [38870, 42501, 44855, 44504, 41194, 42087, 43687, 42347, 45098, 43783, 47275, 49767,
39502, 35951, 47059, 47639, 44236, 40826, 46087, 41462, 38384, 41452, 36811, 37943]
types = ['A', 'B', 'C', 'A', 'B', 'C', 'A', 'B', 'C', 'A', 'B', 'C',
'A', 'B', 'C', 'A', 'B', 'C', 'A', 'B', 'C', 'A', 'B', 'C']
df_x = pd.DataFrame({'timedates': timedates, 'amount': amount, 'types': types})
我发现了如何用 matplotlib 做到这一点
plt.style.use('ggplot')
fig, ax = plt.subplots()
ax.plot_date(df_x.timedates, df_x.amount, 'v-')
ax.xaxis.set_minor_locator(md.MonthLocator())
ax.xaxis.set_minor_formatter(md.DateFormatter('%m'))
ax.xaxis.grid(True, which="minor")
ax.yaxis.grid()
ax.xaxis.set_major_locator(md.YearLocator())
ax.xaxis.set_major_formatter(md.DateFormatter('\n\n%Y'))
plt.show()
现在我转向 seaborn 以考虑不同类型的数据。是否可以使用 seaborn FacetGrid 获得相同样式的刻度?
g = sns.FacetGrid(df_x, hue='types', size=8, aspect=1.5)
g.map(sns.pointplot, 'timedates', 'amount')
plt.show()
【问题讨论】:
-
你看到这个stackoverflow.com/questions/31810316/… 和github.com/mwaskom/seaborn/issues/498。听起来像是 Pandas/Seaborne 和 matplotlib 之间的标签和日期不兼容。您可以手动使用
g.ax.set_xticks([dates, in, format, you, want])解决... -
@EdSmith 是的,我看到了第一个链接,但没有答案。并感谢第二个和代码,我会检查是否可以这样做。
-
可以对g进行迭代,例如:
for ax in g.axes.flat: ax.xaxis.set_major_locator(ticker.MultipleLocator(6))
标签: python matplotlib plot time-series seaborn