Arrow是一个跨语言数据交换的内存列式数据结构。它提供了两个基本的API用于操作数据:表格API和数据集API。
表格API主要用于处理二维数据集,类似于关系型数据库中的表格。它提供了查找、过滤、排序、聚合等常见的数据操作操作。以下是一个示例,演示如何通过表格API创建和操作表格。
import pyarrow as pa
# Create a schema for the table
schema = pa.schema([
('name', pa.string()),
('age', pa.int32()),
('gender', pa.string())
])
# Create a record batch and put it in a table
record_batch = pa.RecordBatch.from_arrays([
pa.array(['Alice', 'Bob', 'Charlie']),
pa.array([25, 30, 35]),
pa.array(['Female', 'Male', 'Male'])
], schema=schema)
table = pa.Table.from_batches([record_batch])
# Perform some operations on the table
filtered_table = table.filter(pa.Expression.col('age') >= 30)
sorted_table = filtered_table.sort('name')
grouped_table = sorted_table.group_by('gender').aggregate([
pa.NamedAggregation('count', pa.aggregate.count('name')),
pa.NamedAggregation('avg_age', pa.aggregate.mean('age'))
])
数据集API则更加通用,能够处理任意维度和类型的数据集。它提供了类似于Spark或Pandas的数据操作函数,如map、filter、reduce等以及并行化执行操作的能力。以下是一个示例,演示如何通过数据集API读取和转换数据集。
import pyarrow.dataset as ds
# Define a dataset from a Parquet file
dataset = ds.dataset('mydata.parquet')
# Define a transformation to apply to the dataset
def filter_and_rename(row):
if row['age'] >= 30:
return {'Name': row['name'], 'Age': row['age']}
else:
return None
# Apply the transformation to the dataset in parallel and write the result
result = ds.dataset(dataset).map(filter_and_rename, schema=pa.schema([('Name', pa.string()), ('Age', pa.int32())]))
result.write_to('result.parquet')
总体而言,表格API适用于处理二维数据、适合做各种SQL-like操作;而数据集API更通用,能够处理任意维度和类型的数据集,适