mea*_*ory 3 python datetime matplotlib pandas
我有我试图使用 Matplotlib 绘制的季度数据。我希望主要的 xtick 标签显示年份,次要的 xtick 标签显示季度。
然而,我所能找到的只是月度数据。也就是说,以下代码(使用 matplotlib 的 mdates 函数)将每月进行次要 xticks,但我没有看到季度选项...
有什么帮助吗?
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
A = pd.DataFrame(np.random.rand(6*4))
A.index = pd.date_range(start = "2017", periods = len(A), freq = "QS")
fig, ax = plt.subplots(figsize = (10,6))
ax.plot(A)
years = mdates.YearLocator() # every year
months = mdates.MonthLocator() # every month
yearsFmt = mdates.DateFormatter('%Y')
ax.xaxis.set_major_locator(years)
ax.xaxis.set_major_formatter(yearsFmt)
ax.xaxis.set_minor_locator(months)
Run Code Online (Sandbox Code Playgroud)
MonthLocator需要几个参数。您可以使用bymonth(第一个)并指定要进行刻度的月份。一个季度包括 3 个月,所以1,4,7,10应该是您所追求的。
months = mdates.MonthLocator((1,4,7,10))
Run Code Online (Sandbox Code Playgroud)