Arrow中表格和数据集API的区别
创始人
2024-11-10 20:00:46
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更通用,能够处理任意维度和类型的数据集,适

相关内容

热门资讯

银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...