在dask中迭代GroupBy对象

Arc*_*ast 7 python pandas dask

是否有可能迭代一个dask GroupBy对象来访问底层数据帧?我试过了:

import dask.dataframe as dd
import pandas as pd
pdf = pd.DataFrame({'A':[1,2,3,4,5], 'B':['1','1','a','a','a']})
ddf = dd.from_pandas(pdf, npartitions = 3)
groups = ddf.groupby('B')
for name, df in groups:
    print(name)
Run Code Online (Sandbox Code Playgroud)

但是,这会导致错误: KeyError: 'Column not found: 0'

更一般地说,除了apply方法之外,dask GroupBy对象允许哪种交互?

Ste*_*n G 6

您可以使用 dask 遍历执行此操作的组,也许有更好的方法,但这对我有用。

import dask.dataframe as dd
import pandas as pd
pdf = pd.DataFrame({'A':[1, 2, 3, 4, 5], 'B':['1','1','a','a','a']})
ddf = dd.from_pandas(pdf, npartitions = 3)
groups = ddf.groupby('B')

for group in pdf['B'].unique():
    print groups.get_group(group)
Run Code Online (Sandbox Code Playgroud)

这将返回

dd.DataFrame<dataframe-groupby-get_group-e3ebb5d5a6a8001da9bb7653fface4c1, divisions=(0, 2, 4, 4)>
dd.DataFrame<dataframe-groupby-get_group-022502413b236592cf7d54b2dccf10a9, divisions=(0, 2, 4, 4)>
Run Code Online (Sandbox Code Playgroud)


MRo*_*lin 5

通常不建议迭代 Dask.dataframe 对象。这是低效的。相反,您可能想尝试构建一个函数并使用该函数在结果组上映射groupby.apply