将 pandas 数据帧转换为多个 numpy 数组

3
我希望将我的列转换为多个数组,使得每行的值来自同一日期。
My data:

Date        Value
2006-12-11  816.2
2006-12-11  816.2
2006-12-11  816.2
2006-12-12  848.2
2006-12-12  849.0
2006-12-13  885.6
2006-12-13  887.0
2006-12-13  885.2
2006-12-13  882.0
2006-12-13  885.0

期望输出:

[[816.2, 816.2, 816.2]
[848.2, 849.0]
[885.6, 887.0, 885.2, 882.0, 885.0]] 
2个回答

4

您可以使用numpy.arraygroupby组合使用:

import numpy as np:

df.Value.groupby(df.Date).apply(np.array).values

例子:

df = pd.DataFrame({
    "Date": ['2006-12-11', '2006-12-11', '2006-12-11', '2006-12-12', '2006-12-12'], 
    'Value': [816.2, 816.2, 816.2, 848.2, 849.0]})
df.Value.groupby(df.Date).apply(np.array).values
array([array([816.2, 816.2, 816.2]), array([848.2, 849. ])], dtype=object)

3
您可以将值转换为列表:
df.groupby(by=df.Date).agg(lambda x: x.tolist()).values

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接