使用 Dask 导入大型 CSV 文件

问题描述

我正在使用 dask 导入一个非常大的 csv 文件 ~680GB,但是,输出不是我所期望的。我的目标是只选择一些列 (6/50),并可能过滤它们(我不确定,因为似乎没有数据?):

import dask.dataframe as dd

file_path = "/Volumes/Seagate/Work/Tickets/Third ticket/Extinction/species_all.csv"

cols = ['year','species','occurrenceStatus','individualCount','decimalLongitude','decimalLatitde']
dataset = dd.read_csv(file_path,names=cols,usecols=[9,18,19,21,22,32])

当我将其读入 Jupyter 时,我无法理解输出 - 控制台输出

dask DataFrame Structure:
                     year species occurrenceStatus individualCount decimalLongitude decimalLatitde
npartitions=11397                                                                                 
                   object  object           object          object           object         object
                      ...     ...              ...             ...              ...            ...
...                   ...     ...              ...             ...              ...            ...
                      ...     ...              ...             ...              ...            ...
                      ...     ...              ...             ...              ...            ...
dask Name: read-csv,11397 tasks

解决方法

看起来您已经成功创建了一个 dask 数据框。如果您期望得到类似 Pandas 数据帧的内容,那么您可以使用 dataset.head() 来查看数据。对于更复杂的计算,最好保持数据集惰性(作为 dask 数据帧),并使用标准 pandas 语法进行所有转换。

# this is needed to call dask.compute
import dask

# for example take a subset
subset_data = dataset[dataset['year']>2000]

# find out the total value for this column
lazy_result = subset_data['individualCount'].sum()

# now that the target is known use .compute
computed_result = dask.compute(lazy_result)

除了 dask,您还可以查看 vaex,对于某些目的可能更好:https://vaex.io/

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...