4

这在熊猫中是可能的。

我想用 dask 来做。

编辑:在这里提出

仅供参考,您可以从xarray.Dataset 转到 Dask.DataFrame

使用.to_xarry 的熊猫解决方案:

import pandas as pd
import numpy as np

df = pd.DataFrame([('falcon', 'bird', 389.0, 2),
                   ('parrot', 'bird', 24.0, 2),
                   ('lion', 'mammal', 80.5, 4),
                   ('monkey', 'mammal', np.nan, 4)],
                  columns=['name', 'class', 'max_speed',
                           'num_legs'])

df.to_xarray()
<xarray.Dataset>
Dimensions:    (index: 4)
Coordinates:
  * index      (index) int64 0 1 2 3
Data variables:
    name       (index) object 'falcon' 'parrot' 'lion' 'monkey'
    class      (index) object 'bird' 'bird' 'mammal' 'mammal'
    max_speed  (index) float64 389.0 24.0 80.5 nan
    num_legs   (index) int64 2 2 4 4

解决方案?

import dask.dataframe as dd

ddf = dd.from_pandas(df, 1)

?

可以使用 xarray 寻找解决方案,但我认为它只有.from_dataframe

import xarray as xr

ds = xr.Dataset()
ds.from_dataframe(ddf.compute())
4

3 回答 3

2

我一直在寻找类似的东西并创建了这个功能(它并不完美,但效果很好)。它还将所有 dask 数据保存为 dask 数组,以节省内存等。

import xarray as xr
import dask.dataframe as dd
        
def dask_2_xarray(ddf, indexname='index'):
     ds = xr.Dataset()
     ds[indexname] = ddf.index
     for key in ddf.columns:
         ds[key] = (indexname, ddf[key].to_dask_array().compute_chunk_sizes())
     return ds
            
# use:
ds = dask_2_xarray(ddf)

例子:

path = LOCATION TO FILE
ddf_test = dd.read_hdf(path, key="/data*", sorted_index=True, mode='r')
ds = dask_2_xarray(ddf_test, indexname="time")
ds

结果: Jup 中的结果数组。 实验室

大部分时间都花在计算块大小上,所以如果有人知道更好的方法来做到这一点,它会更快。

于 2021-05-19T00:02:14.423 回答
2

所以这是可能的,我在这里做了一个 PR 来实现它 - https://github.com/pydata/xarray/pull/4659

它提供了两种方法Dataset.from_dask_dataframeDataArray.from_dask_series.

尚未合并的主要原因是我们试图用尽可能少的 dask 计算来计算块大小。

这些问题中还有更多上下文:https://github.com/pydata/xarray/issues/4650https://github.com/pydata/xarray/issues/3929

于 2021-05-19T07:53:15.983 回答
1

该方法目前不存在。如果您认为它应该存在,那么我鼓励您提出 github 问题作为功能请求。不过,您可能想标记一些 Xarray 人。

于 2020-03-28T17:24:11.307 回答