Arrow中表格和数据集API的区别
创始人
2024-11-10 20:00:25
0

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更通用,能够处理任意维度和类型的数据集,适

相关内容

热门资讯

必备透视!哈糖大菠萝开挂!本来... 必备透视!哈糖大菠萝开挂!本来真的是有辅助软件(了解有挂)-哔哩哔哩亲,关键说明,哈糖大菠萝开挂透视...
辅助透视!epoker有透视吗... 辅助透视!epoker有透视吗,wepoker私人局有透视吗,总结教程(有挂技巧)-哔哩哔哩1、we...
揭幕透视!哈糖大菠萝破解器!一... 揭幕透视!哈糖大菠萝破解器!一直有辅助教程(有挂教程)-哔哩哔哩1、游戏颠覆性的策略玩法,独创攻略技...
详细透视!hhpoker脚本,... 详细透视!hhpoker脚本,wepoker透视脚本视频,指引教程(有挂规律)-哔哩哔哩1、点击下载...
详细透视!约局吧如何查看是否有... 详细透视!约局吧如何查看是否有挂!一贯存在有辅助方法(真的有挂)-哔哩哔哩1、玩家可以在约局吧如何查...
详情透视!hh poker辅助... 详情透视!hh poker辅助有用吗,wepoker辅助透视软件,机巧教程(有挂方略)-哔哩哔哩1、...
教你透视!拱趴大菠萝自动计算机... 教你透视!拱趴大菠萝自动计算机器人!好像是有辅助攻略(竟然有挂)-哔哩哔哩1)拱趴大菠萝自动计算机器...
有挂透视!wepoker透视脚... 有挂透视!wepoker透视脚本免费,hhpoker德州挂真的有吗,演示教程(新版有挂)-哔哩哔哩1...
有挂透视!来玩德州破解器!总是... 有挂透视!来玩德州破解器!总是存在有辅助攻略(有挂头条)-哔哩哔哩1、来玩德州破解器透视辅助软件激活...
有挂透视!德州局透视脚本免费版... 有挂透视!德州局透视脚本免费版下载手机版,aapoker脚本,攻略教程(真实有挂)-哔哩哔哩在进入德...