Best way to generate day-of-week boxplots from a Pandas timeseries

和自甴很熟 提交于 2019-12-03 07:10:22
Joop

1st Create data frame and use weekdays method to get days of week:

import pandas as pd
import numpy.random as random
n=1000
df = pd.DataFrame(random.randn(n), pd.date_range('2010-01-01', periods=n), columns=["data"])
df['Dates'] = df.index
df['week_days'] =df.index.weekday
df

now pivot that table so that the week_days are as columns (could also change the needdays to string formats of days but leaving that for you.

x =df.pivot(index='Dates', columns='week_days', values='data')
x.boxplot()

import locale, calendar
# for example pl_PL
locale.setlocale(locale.LC_ALL, 'pl_PL.UTF-8')
x = x.rename_axis(lambda x: calendar.day_abbr[x].capitalize())
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!