【问题标题】:Best way to generate day-of-week boxplots from a Pandas timeseries从 Pandas 时间序列生成星期几箱线图的最佳方法
【发布时间】:2013-06-16 04:26:11
【问题描述】:

我正在尝试为时间序列创建一组星期几的箱线图(例如 5 分钟的温度观察)。

我的代码:

# ts is our timeseries
ts = df.SomeColumn

dow_map = {}
days = ['MON','TUE','WED','THU','FRI','SAT','SUN']
dow_idx = ts.index.dayofweek

i = 0
for d in days:
    dow_map[d] = ts[dow_idx == i]
    i = i + 1

df = pd.DataFrame(dow_map)
df.boxplot()

结果:

---------------------------------------------------------------------------
Exception                                 Traceback (most recent call last)
<ipython-input-898-6070c45e4c4b> in <module>()
     41     i = i + 1
     42 
---> 43 df = pd.DataFrame(dow_map)
     44 df.boxplot()
...
Exception: Reindexing only valid with uniquely valued Index objects

我确实通过为每周的每一天创建 DataFrame,然后将它们连接到最终的 DataFrame 中找到了成功,但这似乎效率低下...

【问题讨论】:

  • 另外,如果你发现自己在 python 中的 i+=1,你可能做错了(在这种情况下使用 enumerate
  • 你希望这个 DataFrame 是什么样子的?好像会很稀疏……

标签: python pandas time-series boxplot dayofweek


【解决方案1】:

第一次创建数据框并使用 weekdays 方法获取星期几:

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

现在旋转该表,以便将 week_days 作为列(也可以将 needdays 更改为日期的字符串格式,但留给您。

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

【讨论】:

    【解决方案2】:
    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())
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-04-08
      • 2021-12-12
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2019-08-10
      • 2014-11-15
      • 2014-04-10
      相关资源
      最近更新 更多