Лучший способ создания графиков дней недели из временных рядов Pandas

я пытаюсь создать набор графиков дня недели для временного ряда (например, 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

Я добился успеха, создав DataFrames для каждого дня недели, а затем объединив их в окончательный DataFrame, но это кажется неэффективным...


person dkanoafry    schedule 19.06.2013    source источник
comment
Кроме того, если вы когда-нибудь обнаружите, что i+=1 в python, вы, вероятно, делаете это неправильно (в этом случае используйте enumerate)   -  person Andy Hayden    schedule 19.06.2013
comment
Как вы ожидаете, что этот DataFrame будет выглядеть? Вроде бы очень мало...   -  person Andy Hayden    schedule 19.06.2013


Ответы (1)


1. Создайте фрейм данных и используйте метод рабочих дней, чтобы получить дни недели:

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

теперь поверните эту таблицу так, чтобы дни недели были в виде столбцов (можно также изменить нужные дни на строковые форматы дней, но оставив это для вас.

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

введите здесь описание изображения

person Joop    schedule 21.06.2013