gpt4 book ai didi

python - 使用多个时间戳对多个用户数据进行分组

转载 作者:行者123 更新时间:2023-12-01 09:11:20 26 4
gpt4 key购买 nike

我有一个正在尝试处理的数据框(如下所示)。

|   user  | weight | height | timestamp                       |
| ------ | ----- |------ |---------------------------------|
| user 1 | NA | 180 | 2017-11-09 17:21:49.025259+00:00|
| user 1 | 90 | NA | 2017-11-09 17:21:49.025259+00:00|
| user 1 | 89 | NA | 2017-11-10 17:21:49.025259+00:00|
| user 1 | 88 | NA | 2017-11-11 17:21:49.025259+00:00|
| user 2 | NA | 175 | 2017-11-09 17:21:49.025259+00:00|
| user 2 | 95 | NA | 2017-11-09 17:21:49.025259+00:00|
| user 3 | NA | 170 | 2017-12-09 17:21:49.025259+00:00|
| user 4 | 70 | NA | 2017-08-09 17:21:49.025259+00:00|

我的最终目标是使用每个体重和高度的最新时间戳数据来计算每个用户的 BMI。一些用户只有一项数据,许多用户拥有体重、高度或两者以上的一项数据。由于数据单位为公斤和厘米,因此 BMI 为

BMI =(体重(公斤)x 10,000)/((高度(厘米)^2)

我希望返回类似以下内容。 (一本字典就足够了)

|   user  |         BMI       |
| ------ | ------------------|
| user 1 | 27.1604938272 |
| user 2 | 31.0204081633 |
| user 3 | NA |
| user 4 | NA |

最佳答案

用途:

#convert to datetimes
df['timestamp'] = pd.to_datetime(df['timestamp'])
#sorting df by datetimes
df = df.sort_values('timestamp')
#for each group get last non NaN value
df1 = df.groupby('user').last()

#apply formula
BMI = (df1['weight'] * 10000 / (df1['height'])**2).reset_index(name='BMI')
print (BMI)
user BMI
0 user 1 27.160494
1 user 2 31.020408
2 user 3 NaN
3 user 4 NaN

#for dictionary
d = (df1['weight'] * 10000 / (df1['height'])**2).to_dict()
print (d)
{'user 1': 27.160493827160494,
'user 2': 31.020408163265305,
'user 3': nan,
'user 4': nan}

关于python - 使用多个时间戳对多个用户数据进行分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51631063/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com