私はint
またはfloat
の加重平均をdatetime
フィールドとする方法を見つけようとしています。私はdatetime
をint
に変換し、数学を行い、datetime
に変換する行について考えています。しかし、そうする方法がわからない。どんな助けも大歓迎です。DataFrame内のInt/Float加重平均日時
私はここではっきりしていたはずです。実際の問題は、今私はId
をGROUPBYとQty
加重StartTime
を取るしようとしています。この
>>> df1 = pd.DataFrame({'Date': {0: '2016-10-11', 1: '2016-10-11', 2: '2016-10-11', 3: '2016-10-11', 4: '2016-10-11',5: '2016-10-11'}, 'Qty': {0: 100, 1: 3232, 2: 4232, 3: 4322, 4: 666, 5: 98}, 'StartTime': {0: '08:00:00.241', 1: '08:00:00.243', 2: '12:34:23.563', 3: '08:14:05.908', 4: '18:54:50.100', 5: '10:08:36.657'},'Id':{0:'abc',1:'abc',2:'bcd',3:'bcd',4:'abc',5:'bcd'}})
>>> df1
Date Id Qty StartTime
0 2016-10-11 abc 100 08:00:00.241
1 2016-10-11 abc 3232 08:00:00.243
2 2016-10-11 bcd 4232 12:34:23.563
3 2016-10-11 bcd 4322 08:14:05.908
4 2016-10-11 abc 666 18:54:50.100
5 2016-10-11 bcd 98 10:08:36.657
>>> df1['StartTime'] = pd.to_datetime(df1['Date'] + ' ' + df1['StartTime'])
>>> df1['StartTime'][0]
Timestamp('2016-10-11 08:00:00.241000')
ような何かを行うことです。 StartTime
にはマイクロ秒のコンポーネントも含まれています。
次はStartTime
列の各項目がTimestamp
であっても、動作していないよう:
>>> (df1.groupby['Id']).apply(lambda x:np.average(x['StartTime'], weights=x['Qty']))
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'instancemethod' object has no attribute '__getitem__'
タイムスタンプを使用することができます。 –