python – 格式化日期时间标签以包括pandas plot的工作日名称

我想将相应的工作日名称(星期一,星期二等)添加到xlabels中以获取pandas timeseries图.

《python – 格式化日期时间标签以包括pandas plot的工作日名称》

import pandas as pd
import numpy as np
import pylab as p
import datetime

dates = pd.date_range(datetime.datetime.today().date(), periods=10, freq='D')
data = pd.DataFrame(np.arange(10),index=dates,columns=['A'])
a = data['A'].plot()
p.tight_layout()
p.show()

我尝试使用以下方法调整格式:

from matplotlib.dates import DateFormatter
formatter = DateFormatter('%a %d-%m-%Y')
a.xaxis.set_major_formatter(formatter)

但这不起作用,导致日期和年份不正确.

似乎应该有一个非常简单的解决方案,但我找不到它.

最佳答案 这是我认为可以工作但没有:

from matplotlib.ticker import FuncFormatter
from matplotlib import pyplot as plt

ax = data.A.plot()
ax.xaxis.set_major_formatter(FuncFormatter(lambda d, _: d.strftime('%a')))

要么

ax = plt.subplot()
ax.plot(data.index, data.A)
ax.xaxis.set_major_formatter(FuncFormatter(lambda d, _: d.strftime('%a')))

这些都以不同的方式出错.在两种情况下,格式化程序输入似乎都是浮点数而不是日期.在第一个函数中,函数仅应用于第一个和最后一个刻度.你可以通过传递看到这一点

ax.xaxis.set_major_formatter(FuncFormatter(lambda d, _: d) 

这是一个非常灵活的解决方案:

ax = plt.subplot()
ax.plot(data.index, data.A)
ticks = ax.set_xticklabels([d.strftime('%a') for d in data.index])

你可以在最后一行交换列表理解,无论你喜欢什么.

编辑:

我想我已经弄清楚这些代表xticks的数字是什么意思.

In [37]: 
ax = plt.subplot()
ax.plot(data.index, data.A)
print  ax.get_xticks()
[ 735824.  735825.  735826.  735827.  735828.  735829.  735830.  735831.
  735832.  735833.]

这些似乎代表自公元1年开始以来的天数:根据这个:http://www.epochconverter.com/epoch/seconds-days-since-year-0.php

“截至今日(2015年8月14日),有736189天.”

这正好是735824(第一个滴答)365.到目前为止一直很糟糕.
你可以(我不会打扰)编写一个函数来将这个数字转换成日期.另一种方法是:

def get_day(tick):
    date = dates[0] + datetime.timedelta(tick - ticks[0])
    return date.strftime('%a')

ax = plt.subplot()
ax.plot(data.index, data.A)
ticks = ax.get_xticks()
ax.xaxis.set_major_formatter(FuncFormatter(lambda tick, _: get_day(tick)))

同样,您可以将所需的日期格式转换为get_day.不确定这是否会解决平移/缩放问题,但至少它提供了一种使用函数设置刻度标签的方法.

点赞