Matplotlib应用xaxis和yaxis数字格式

时间:2016-04-02 06:35:09

标签: python matplotlib formatting axis-labels

  1. 为什么我的xaxis没有格式化为日期?我期待它,因为我将数据帧索引设置为日期时间索引。
  2. 如何让所有子图共享相同的xaxis?我目前使用add_subplot而非plt.subplots的原因是因为我无法获取plt.subplots为我想做的事情工作 - 这是制作nrowsncols 动态参数,这样我就可以输出我想要的任何形状的图表:(4,1)形状,(2,2),(1,4)等。
  3. 如何为每个yaxis应用特定的数字格式?下面,我尝试在d(dict)中查找绘图字符串以返回格式字符串然后应用格式化为yaxis格式,但它似乎没有工作。
  4. import pandas as pd
    import numpy as np
    import matplotlib.pyplot as plt
    from matplotlib.ticker import FuncFormatter
    plt.style.use('ggplot')
    
    df = pd.DataFrame({'Clicks': {0: 334, 1: 554, 2: 433, 3: 5353, 4: 433},
                       'Impressions': {0: 3242, 1: 43345, 2: 3456, 3: 34543, 4: 3453},
                       'Day': {0: '12/1/2015', 1: '12/2/2015', 2: '12/3/2015', 3: '12/4/2015', 4: '12/5/2015'},
                       'Conv': {0: 23, 1: 23, 2: 45, 3: 56, 4: 45},
                       'Cost': {0: 414.16, 1: 686.96, 2: 536.91, 3: 637.72, 4: 536.91}},
                      columns=['Day', 'Impressions', 'Clicks', 'Cost', 'Conv'])
    
    df['Day'] = pd.to_datetime(df['Day'])
    df = df.set_index('Day').resample('d', how='sum')
    
    window = 2
    nrows = 2
    ncols = 2
    
    plots = ['Impressions', 'Clicks', 'Cost', 'Conv']
    d = {'Impressions':'{:,.0f}', 'Clicks': '{:,.0f}', 'Cost':'${:,.2f}', 'Conv': '{:,.0f}'}
    
    fig = plt.figure(figsize=(8,6))
    for i, plot in enumerate(plots):
      ax = fig.add_subplot(nrows, ncols, i+1)
      ax.plot(df.index, df[plot])
      ma = pd.rolling_mean(df[plot], window)
      ax.plot(df.index, ma)
      mstd = pd.rolling_std(df[plot], window)
      ax.fill_between(df.index, ma - 2*mstd, ma + 2*mstd, color='b', alpha=0.1)
      ax.set_title(plot)
      ax.get_yaxis().set_major_formatter(FuncFormatter(lambda x, p: d[plot].format(x)))
      plt.tight_layout()
    
    plt.show()
    

    Plot example

    这是df

                Impressions  Clicks    Cost  Conv
    Day                                          
    2015-12-01         3242     334  414.16    23
    2015-12-02        43345     554  686.96    23
    2015-12-03         3456     433  536.91    45
    2015-12-04        34543    5353  637.72    56
    2015-12-05         3453     433  536.91    45
    

1 个答案:

答案 0 :(得分:1)

  

为什么我的xaxis没有格式化为日期?

您需要将DateFormatter(或类似)设为major_formatter - 请参阅下面的代码。

  

如何让所有子图共享相同的xaxis?

sharex=True参数添加到子图调用中。 如果你将它们展平,可以使用.subplots()中的轴,如下面的代码所示。

  

如何为每个yaxis应用特定的数字格式?

您的FuncFormatter需要返回来自给定tick_valueposition的格式化字符串,如下面的代码所示:

fig, axes = plt.subplots(2, 2, figsize=(8,6), sharex=True)

for ax, plot in zip(axes.flat, plots):
    ax.plot(df.index, df[plot])
    ma = pd.rolling_mean(df[plot], window)
    ax.plot(df.index, ma)
    mstd = pd.rolling_std(df[plot], window)
    ax.fill_between(df.index, ma - 2*mstd, ma + 2*mstd, color='b', alpha=0.1)
    ax.set_title(plot)
    ax.yaxis.set_major_formatter(FuncFormatter(lambda x, p: '{:.0f}'.format(x)))
    ax.xaxis.set_major_formatter(DateFormatter('%d-%H:%M')) # or '%d.%m.%y'

fig.autofmt_xdate()  # This will rotate the xticklabels by 30 degrees so that all dates are readable.
fig.tight_layout()  # no need to call this inside the loop.

这会产生这样的情节:

enter image description here