pandas 如何使用所有 xticks 绘制熊猫多索引数据帧

声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 原文地址: http://stackoverflow.com/questions/21281322/
Warning: these are provided under cc-by-sa 4.0 license. You are free to use/share it, But you must attribute it to the original authors (not me): StackOverFlow

提示:将鼠标放在中文语句上可以显示对应的英文。显示中英文
时间:2020-09-13 21:36:18  来源:igfitidea点击:

How to plot a pandas multiindex dataFrame with all xticks

pythonmatplotlibplotpandas

提问by SwenMulderij

I have a pandas dataFrame like this:

我有一个像这样的Pandas数据框:

                     content
date                        
2013-12-18 12:30:00        1
2013-12-19 10:50:00        1
2013-12-24 11:00:00        0
2014-01-02 11:30:00        1
2014-01-03 11:50:00        0
2013-12-17 16:40:00       10
2013-12-18 10:00:00        0
2013-12-11 10:00:00        0
2013-12-18 11:45:00        0
2013-12-11 14:40:00        4
2010-05-25 13:05:00        0
2013-11-18 14:10:00        0
2013-11-27 11:50:00        3
2013-11-13 10:40:00        0
2013-11-20 10:40:00        1
2008-11-04 14:49:00        1
2013-11-18 10:05:00        0
2013-08-27 11:00:00        0
2013-09-18 16:00:00        0
2013-09-27 11:40:00        0

date being the index. I reduce the values to months using:

日期是索引。我使用以下方法将值减少到几个月:

dataFrame = dataFrame.groupby([lambda x: x.year, lambda x: x.month]).agg([sum])

which outputs:

输出:

         content
             sum
2006 3        66
     4        65
     5        48
     6        87
     7        37
     8        54
     9        73
     10       74
     11       53
     12       45
2007 1        28
     2        40
     3        95
     4        63
     5        56
     6        66
     7        50
     8        49
     9        18
     10       28

Now when I plot this dataFrame, I want the x-axis show every month/year as a tick. I have tries setting xticks but it doesn't seem to work. How could this be achieved? This is my current plot using dataFrame.plot():

现在,当我绘制这个数据框时,我希望每个月/年的 x 轴显示为一个勾号。我曾尝试设置 xticks,但似乎不起作用。这怎么可能实现?这是我当前使用 dataFrame.plot() 绘制的图:

enter image description here

在此处输入图片说明

回答by HYRY

You can use set_xtick()and set_xticklabels():

您可以使用set_xtick()set_xticklabels()

idx = pd.date_range("2013-01-01", periods=1000)
val = np.random.rand(1000)
s = pd.Series(val, idx)

g = s.groupby([s.index.year, s.index.month]).mean()

ax = g.plot()
ax.set_xticks(range(len(g)));
ax.set_xticklabels(["%s-%02d" % item for item in g.index.tolist()], rotation=90);

output:

输出:

enter image description here

在此处输入图片说明