9

時系列の一連の曜日の箱ひげ図を作成しようとしています (例: 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

曜日ごとにデータフレームを作成し、それらを最終的なデータフレームに連結することで成功しましたが、これは非効率的です...

4

2 に答える 2

11

まず、データ フレームを作成し、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()

ここに画像の説明を入力

于 2013-06-21T12:21:05.573 に答える
1
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())
于 2014-01-02T20:27:16.373 に答える