Dataset

Interface

class Fragment : public std::enable_shared_from_this<Fragment>

A granular piece of a Dataset, such as an individual file.

A Fragment can be read/scanned separately from other fragments. It yields a collection of RecordBatches when scanned, encapsulated in one or more ScanTasks.

Note that Fragments have well defined physical schemas which are reconciled by the Datasets which contain them; these physical schemas may differ from a parent Dataset’s schema and the physical schemas of sibling Fragments.

Subclassed by arrow::dataset::FileFragment, arrow::dataset::InMemoryFragment

Public Functions

Result<std::shared_ptr<Schema>> ReadPhysicalSchema()

Return the physical schema of the Fragment.

The physical schema is also called the writer schema. This method is blocking and may suffer from high latency filesystem. The schema is cached after being read once, or may be specified at construction.

virtual Result<ScanTaskIterator> Scan(std::shared_ptr<ScanOptions> options) = 0

Scan returns an iterator of ScanTasks, each of which yields RecordBatches from this Fragment.

Note that batches yielded using this method will not be filtered and may not align with the Fragment’s schema. In particular, note that columns referenced by the filter may be present in yielded batches even if they are not projected (so that they are available when a filter is applied). Additionally, explicitly projected columns may be absent if they were not present in this fragment.

To receive a record batch stream which is fully filtered and projected, use Scanner.

const Expression &partition_expression() const

An expression which evaluates to true for all data viewed by this Fragment.

class Dataset : public std::enable_shared_from_this<Dataset>

A container of zero or more Fragments.

A Dataset acts as a union of Fragments, e.g. files deeply nested in a directory. A Dataset has a schema to which Fragments must align during a scan operation. This is analogous to Avro’s reader and writer schema.

Subclassed by arrow::dataset::FileSystemDataset, arrow::dataset::InMemoryDataset, arrow::dataset::UnionDataset

Public Functions

Result<std::shared_ptr<ScannerBuilder>> NewScan(std::shared_ptr<ScanOptions> options)

Begin to build a new Scan operation against this Dataset.

Result<FragmentIterator> GetFragments(Expression predicate)

GetFragments returns an iterator of Fragments given a predicate.

const Expression &partition_expression() const

An expression which evaluates to true for all data viewed by this Dataset.

May be null, which indicates no information is available.

virtual std::string type_name() const = 0

The name identifying the kind of Dataset.

virtual Result<std::shared_ptr<Dataset>> ReplaceSchema(std::shared_ptr<Schema> schema) const = 0

Return a copy of this Dataset with a different schema.

The copy will view the same Fragments. If the new schema is not compatible with the original dataset’s schema then an error will be raised.

Partitioning

constexpr char arrow::dataset::kDefaultHiveNullFallback[] = "__HIVE_DEFAULT_PARTITION__"

The default fallback used for null values in a Hive-style partitioning.

std::string arrow::dataset::StripPrefixAndFilename(const std::string &path, const std::string &prefix)

Remove a prefix and the filename of a path.

e.g., StripPrefixAndFilename("/data/year=2019/c.txt", "/data") -> "year=2019"

std::vector<std::string> arrow::dataset::StripPrefixAndFilename(const std::vector<std::string> &paths, const std::string &prefix)

Vector version of StripPrefixAndFilename.

std::vector<std::string> arrow::dataset::StripPrefixAndFilename(const std::vector<fs::FileInfo> &files, const std::string &prefix)

Vector version of StripPrefixAndFilename.

class Partitioning
#include <arrow/dataset/partition.h>

Interface for parsing partition expressions from string partition identifiers.

For example, the identifier “foo=5” might be parsed to an equality expression between the “foo” field and the value 5.

Some partitionings may store the field names in a metadata store instead of in file paths, for example dataset_root/2009/11/… could be used when the partition fields are “year” and “month”

Paths are consumed from left to right. Paths must be relative to the root of a partition; path prefixes must be removed before passing the path to a partitioning for parsing.

Subclassed by arrow::dataset::FunctionPartitioning, arrow::dataset::KeyValuePartitioning

Public Functions

virtual std::string type_name() const = 0

The name identifying the kind of partitioning.

virtual Result<Expression> Parse(const std::string &path) const = 0

Parse a path into a partition expression.

const std::shared_ptr<Schema> &schema()

The partition schema.

Public Static Functions

static std::shared_ptr<Partitioning> Default()

A default Partitioning which always yields scalar(true)

struct PartitionedBatches
#include <arrow/dataset/partition.h>

If the input batch shares any fields with this partitioning, produce sub-batches which satisfy mutually exclusive Expressions.

struct PartitioningFactoryOptions
#include <arrow/dataset/partition.h>

Options for inferring a partitioning.

Subclassed by arrow::dataset::HivePartitioningFactoryOptions

Public Members

bool infer_dictionary = false

When inferring a schema for partition fields, yield dictionary encoded types instead of plain.

This can be more efficient when materializing virtual columns, and Expressions parsed by the finished Partitioning will include dictionaries of all unique inspected values for each field.

std::shared_ptr<Schema> schema

Optionally, an expected schema can be provided, in which case inference will only check discovered fields against the schema and update internal state (such as dictionaries).

struct HivePartitioningFactoryOptions : public arrow::dataset::PartitioningFactoryOptions
#include <arrow/dataset/partition.h>

Options for inferring a hive-style partitioning.

Public Members

std::string null_fallback

The hive partitioning scheme maps null to a hard coded fallback string.

class PartitioningFactory
#include <arrow/dataset/partition.h>

PartitioningFactory provides creation of a partitioning when the specific schema must be inferred from available paths (no explicit schema is known).

Public Functions

virtual std::string type_name() const = 0

The name identifying the kind of partitioning.

virtual Result<std::shared_ptr<Schema>> Inspect(const std::vector<std::string> &paths) = 0

Get the schema for the resulting Partitioning.

This may reset internal state, for example dictionaries of unique representations.

virtual Result<std::shared_ptr<Partitioning>> Finish(const std::shared_ptr<Schema> &schema) const = 0

Create a partitioning using the provided schema (fields may be dropped).

class KeyValuePartitioning : public arrow::dataset::Partitioning
#include <arrow/dataset/partition.h>

Subclass for the common case of a partitioning which yields an equality expression for each segment.

Subclassed by arrow::dataset::DirectoryPartitioning, arrow::dataset::HivePartitioning

Public Functions

Result<Expression> Parse(const std::string &path) const

Parse a path into a partition expression.

struct Key
#include <arrow/dataset/partition.h>

An unconverted equality expression consisting of a field name and the representation of a scalar value.

class DirectoryPartitioning : public arrow::dataset::KeyValuePartitioning
#include <arrow/dataset/partition.h>

DirectoryPartitioning parses one segment of a path for each field in its schema.

All fields are required, so paths passed to DirectoryPartitioning::Parse must contain segments for each field.

For example given schema<year:int16, month:int8> the path “/2009/11” would be parsed to (“year”_ == 2009 and “month”_ == 11)

Public Functions

DirectoryPartitioning(std::shared_ptr<Schema> schema, ArrayVector dictionaries = {})

If a field in schema is of dictionary type, the corresponding element of dictionaries must be contain the dictionary of values for that field.

std::string type_name() const

The name identifying the kind of partitioning.

Public Static Functions

static std::shared_ptr<PartitioningFactory> MakeFactory(std::vector<std::string> field_names, PartitioningFactoryOptions = {})

Create a factory for a directory partitioning.

Parameters
  • [in] field_names: The names for the partition fields. Types will be inferred.

class HivePartitioning : public arrow::dataset::KeyValuePartitioning
#include <arrow/dataset/partition.h>

Multi-level, directory based partitioning originating from Apache Hive with all data files stored in the leaf directories.

Data is partitioned by static values of a particular column in the schema. Partition keys are represented in the form $key=$value in directory names. Field order is ignored, as are missing or unrecognized field names.

For example given schema<year:int16, month:int8, day:int8> the path “/day=321/ignored=3.4/year=2009” parses to (“year”_ == 2009 and “day”_ == 321)

Public Functions

HivePartitioning(std::shared_ptr<Schema> schema, ArrayVector dictionaries = {}, std::string null_fallback = kDefaultHiveNullFallback)

If a field in schema is of dictionary type, the corresponding element of dictionaries must be contain the dictionary of values for that field.

std::string type_name() const

The name identifying the kind of partitioning.

Public Static Functions

static std::shared_ptr<PartitioningFactory> MakeFactory(HivePartitioningFactoryOptions = {})

Create a factory for a hive partitioning.

class FunctionPartitioning : public arrow::dataset::Partitioning
#include <arrow/dataset/partition.h>

Implementation provided by lambda or other callable.

Public Functions

std::string type_name() const

The name identifying the kind of partitioning.

Result<Expression> Parse(const std::string &path) const

Parse a path into a partition expression.

class PartitioningOrFactory
#include <arrow/dataset/partition.h>

Either a Partitioning or a PartitioningFactory.

Public Functions

const std::shared_ptr<Partitioning> &partitioning() const

The partitioning (if given).

const std::shared_ptr<PartitioningFactory> &factory() const

The partition factory (if given).

Result<std::shared_ptr<Schema>> GetOrInferSchema(const std::vector<std::string> &paths)

Get the partition schema, inferring it with the given factory if needed.

Dataset discovery/factories

struct InspectOptions
#include <arrow/dataset/discovery.h>

Public Members

int fragments = 1

Indicate how many fragments should be inspected to infer the unified dataset schema.

Limiting the number of fragments accessed improves the latency of the discovery process when dealing with a high number of fragments and/or high latency file systems.

The default value of 1 inspects the schema of the first (in no particular order) fragment only. If the dataset has a uniform schema for all fragments, this default is the optimal value. In order to inspect all fragments and robustly unify their potentially varying schemas, set this option to kInspectAllFragments. A value of 0 disables inspection of fragments altogether so only the partitioning schema will be inspected.

Public Static Attributes

constexpr int kInspectAllFragments = -1

See fragments property.

struct FinishOptions
#include <arrow/dataset/discovery.h>

Public Members

std::shared_ptr<Schema> schema = NULLPTR

Finalize the dataset with this given schema.

If the schema is not provided, infer the schema via the Inspect, see the inspect_options property.

InspectOptions inspect_options = {}

If the schema is not provided, it will be discovered by passing the following options to DatasetDiscovery::Inspect.

bool validate_fragments = false

Indicate if the given Schema (when specified), should be validated against the fragments’ schemas.

inspect_options will control how many fragments are checked.

class DatasetFactory
#include <arrow/dataset/discovery.h>

DatasetFactory provides a way to inspect/discover a Dataset’s expected schema before materializing said Dataset.

Subclassed by arrow::dataset::FileSystemDatasetFactory, arrow::dataset::ParquetDatasetFactory, arrow::dataset::UnionDatasetFactory

Public Functions

virtual Result<std::vector<std::shared_ptr<Schema>>> InspectSchemas(InspectOptions options) = 0

Get the schemas of the Fragments and Partitioning.

Result<std::shared_ptr<Schema>> Inspect(InspectOptions options = {})

Get unified schema for the resulting Dataset.

Result<std::shared_ptr<Dataset>> Finish()

Create a Dataset.

Result<std::shared_ptr<Dataset>> Finish(std::shared_ptr<Schema> schema)

Create a Dataset with the given schema (see InspectOptions::schema)

virtual Result<std::shared_ptr<Dataset>> Finish(FinishOptions options) = 0

Create a Dataset with the given options.

const Expression &root_partition() const

Optional root partition for the resulting Dataset.

Status SetRootPartition(Expression partition)

Set the root partition for the resulting Dataset.

Scanning

using arrow::dataset::TaggedRecordBatchGenerator = std::function<Future<TaggedRecordBatch>()>
using arrow::dataset::TaggedRecordBatchIterator = Iterator<TaggedRecordBatch>
using arrow::dataset::EnumeratedRecordBatchGenerator = std::function<Future<EnumeratedRecordBatch>()>
using arrow::dataset::EnumeratedRecordBatchIterator = Iterator<EnumeratedRecordBatch>
constexpr int64_t arrow::dataset::kDefaultBatchSize = 1 << 20
constexpr int32_t arrow::dataset::kDefaultBatchReadahead = 32
constexpr int32_t arrow::dataset::kDefaultFragmentReadahead = 8
class FragmentScanOptions
#include <arrow/dataset/dataset.h>

Per-scan options for fragment(s) in a dataset.

These options are not intrinsic to the format or fragment itself, but do affect the results of a scan. These are options which make sense to change between repeated reads of the same dataset, such as format-specific conversion options (that do not affect the schema).

Subclassed by arrow::dataset::CsvFragmentScanOptions, arrow::dataset::IpcFragmentScanOptions, arrow::dataset::ParquetFragmentScanOptions

struct ScanOptions
#include <arrow/dataset/scanner.h>

Scan-specific options, which can be changed between scans of the same dataset.

Public Members

Expression filter = literal(true)

A row filter (which will be pushed down to partitioning/reading if supported).

Expression projection

A projection expression (which can add/remove/rename columns).

std::shared_ptr<Schema> dataset_schema

Schema with which batches will be read from fragments.

This is also known as the “reader schema” it will be used (for example) in constructing CSV file readers to identify column types for parsing. Usually only a subset of its fields (see MaterializedFields) will be materialized during a scan.

std::shared_ptr<Schema> projected_schema

Schema of projected record batches.

This is independent of dataset_schema as its fields are derived from the projection. For example, let

dataset_schema = {“a”: int32, “b”: int32, “id”: utf8} projection = project({equal(field_ref(“a”), field_ref(“b”))}, {“a_plus_b”})

(no filter specified). In this case, the projected_schema would be

{“a_plus_b”: int32}

int64_t batch_size = kDefaultBatchSize

Maximum row count for scanned batches.

int32_t batch_readahead = kDefaultBatchReadahead

How many batches to read ahead within a file.

Set to 0 to disable batch readahead

Note: May not be supported by all formats Note: May not be supported by all scanners Note: Will be ignored if use_threads is set to false

int32_t fragment_readahead = kDefaultFragmentReadahead

How many files to read ahead.

Set to 0 to disable fragment readahead

Note: May not be enforced by all scanners Note: Will be ignored if use_threads is set to false

MemoryPool *pool = arrow::default_memory_pool()

A pool from which materialized and scanned arrays will be allocated.

internal::Executor *cpu_executor = internal::GetCpuThreadPool()

Executor on which to run any CPU tasks.

Note: Will be ignored if use_threads is set to false

io::IOContext io_context

IOContext for any IO tasks.

Note: The IOContext executor will be ignored if use_threads is set to false

bool use_threads = false

If true the scanner will scan in parallel.

Note: If true, this will use threads from both the cpu_executor and the io_context.executor Note: This must be true in order for any readahead to happen

bool use_async = false

If true then an asycnhronous implementation of the scanner will be used.

This implementation is newer and generally performs better. However, it makes extensive use of threading and is still considered experimental

std::shared_ptr<FragmentScanOptions> fragment_scan_options

Fragment-specific scan options.

class ScanTask
#include <arrow/dataset/scanner.h>

Read record batches from a range of a single data fragment.

A ScanTask is meant to be a unit of work to be dispatched. The implementation must be thread and concurrent safe.

Subclassed by arrow::dataset::InMemoryScanTask

Public Functions

virtual Result<RecordBatchIterator> Execute() = 0

Iterate through sequence of materialized record batches resulting from the Scan.

Execution semantics are encapsulated in the particular ScanTask implementation

struct TaggedRecordBatch
#include <arrow/dataset/scanner.h>

Combines a record batch with the fragment that the record batch originated from.

Knowing the source fragment can be useful for debugging & understanding loaded data

struct EnumeratedRecordBatch
#include <arrow/dataset/scanner.h>

Combines a tagged batch with positional information.

This is returned when scanning batches in an unordered fashion. This information is needed if you ever want to reassemble the batches in order

class Scanner
#include <arrow/dataset/scanner.h>

A scanner glues together several dataset classes to load in data.

The dataset contains a collection of fragments and partitioning rules.

The fragments identify independently loadable units of data (i.e. each fragment has a potentially unique schema and possibly even format. It should be possible to read fragments in parallel if desired).

The fragment’s format contains the logic necessary to actually create a task to load the fragment into memory. That task may or may not support parallel execution of its own.

The scanner is then responsible for creating scan tasks from every fragment in the dataset and (potentially) sequencing the loaded record batches together.

The scanner should not buffer the entire dataset in memory (unless asked) instead yielding record batches as soon as they are ready to scan. Various readahead properties control how much data is allowed to be scanned before pausing to let a slow consumer catchup.

Today the scanner also handles projection & filtering although that may change in the future.

Subclassed by arrow::dataset::SyncScanner

Public Functions

virtual Result<ScanTaskIterator> Scan()

The Scan operator returns a stream of ScanTask.

The caller is responsible to dispatch/schedule said tasks. Tasks should be safe to run in a concurrent fashion and outlive the iterator.

Note: Not supported by the async scanner Planned for removal from the public API in ARROW-11782.

virtual Status Scan(std::function<Status(TaggedRecordBatch)> visitor) = 0

Apply a visitor to each RecordBatch as it is scanned.

If multiple threads are used (via use_threads), the visitor will be invoked from those threads and is responsible for any synchronization.

virtual Result<std::shared_ptr<Table>> ToTable() = 0

Convert a Scanner into a Table.

Use this convenience utility with care. This will serially materialize the Scan result in memory before creating the Table.

virtual Result<TaggedRecordBatchIterator> ScanBatches() = 0

Scan the dataset into a stream of record batches.

Each batch is tagged with the fragment it originated from. The batches will arrive in order. The order of fragments is determined by the dataset.

Note: The scanner will perform some readahead but will avoid materializing too much in memory (this is goverended by the readahead options and use_threads option). If the readahead queue fills up then I/O will pause until the calling thread catches up.

virtual Result<EnumeratedRecordBatchIterator> ScanBatchesUnordered()

Scan the dataset into a stream of record batches.

Unlike ScanBatches this method may allow record batches to be returned out of order. This allows for more efficient scanning: some fragments may be accessed more quickly than others (e.g. may be cached in RAM or just happen to get scheduled earlier by the I/O)

To make up for the out-of-order iteration each batch is further tagged with positional information.

virtual Result<std::shared_ptr<Table>> TakeRows(const Array &indices)

A convenience to synchronously load the given rows by index.

Will only consume as many batches as needed from ScanBatches().

virtual Result<std::shared_ptr<Table>> Head(int64_t num_rows)

Get the first N rows.

const std::shared_ptr<ScanOptions> &options() const

Get the options for this scan.

class SyncScanner : public arrow::dataset::Scanner
#include <arrow/dataset/scanner.h>

Public Functions

Result<TaggedRecordBatchIterator> ScanBatches()

Scan the dataset into a stream of record batches.

Each batch is tagged with the fragment it originated from. The batches will arrive in order. The order of fragments is determined by the dataset.

Note: The scanner will perform some readahead but will avoid materializing too much in memory (this is goverended by the readahead options and use_threads option). If the readahead queue fills up then I/O will pause until the calling thread catches up.

Result<ScanTaskIterator> Scan()

The Scan operator returns a stream of ScanTask.

The caller is responsible to dispatch/schedule said tasks. Tasks should be safe to run in a concurrent fashion and outlive the iterator.

Note: Not supported by the async scanner Planned for removal from the public API in ARROW-11782.

Status Scan(std::function<Status(TaggedRecordBatch)> visitor)

Apply a visitor to each RecordBatch as it is scanned.

If multiple threads are used (via use_threads), the visitor will be invoked from those threads and is responsible for any synchronization.

Result<std::shared_ptr<Table>> ToTable()

Convert a Scanner into a Table.

Use this convenience utility with care. This will serially materialize the Scan result in memory before creating the Table.

class ScannerBuilder
#include <arrow/dataset/scanner.h>

ScannerBuilder is a factory class to construct a Scanner.

It is used to pass information, notably a potential filter expression and a subset of columns to materialize.

Public Functions

Status Project(std::vector<std::string> columns)

Set the subset of columns to materialize.

Columns which are not referenced may not be read from fragments.

Return

Failure if any column name does not exists in the dataset’s Schema.

Parameters
  • [in] columns: list of columns to project. Order and duplicates will be preserved.

Status Project(std::vector<Expression> exprs, std::vector<std::string> names)

Set expressions which will be evaluated to produce the materialized columns.

Columns which are not referenced may not be read from fragments.

Return

Failure if any referenced column does not exists in the dataset’s Schema.

Parameters
  • [in] exprs: expressions to evaluate to produce columns.

  • [in] names: list of names for the resulting columns.

Status Filter(const Expression &filter)

Set the filter expression to return only rows matching the filter.

The predicate will be passed down to Sources and corresponding Fragments to exploit predicate pushdown if possible using partition information or Fragment internal metadata, e.g. Parquet statistics. Columns which are not referenced may not be read from fragments.

Return

Failure if any referenced columns does not exist in the dataset’s Schema.

Parameters
  • [in] filter: expression to filter rows with.

Status UseThreads(bool use_threads = true)

Indicate if the Scanner should make use of the available ThreadPool found in ScanOptions;.

Status BatchSize(int64_t batch_size)

Set the maximum number of rows per RecordBatch.

This option provides a control limiting the memory owned by any

RecordBatch.
Return

An error if the number for batch is not greater than 0.

Parameters
  • [in] batch_size: the maximum number of rows.

Status Pool(MemoryPool *pool)

Set the pool from which materialized and scanned arrays will be allocated.

Status FragmentScanOptions(std::shared_ptr<FragmentScanOptions> fragment_scan_options)

Set fragment-specific scan options.

Result<std::shared_ptr<Scanner>> Finish()

Return the constructed now-immutable Scanner object.

Concrete implementations

class InMemoryFragment : public arrow::dataset::Fragment
#include <arrow/dataset/dataset.h>

A trivial Fragment that yields ScanTask out of a fixed set of RecordBatch.

Public Functions

Result<ScanTaskIterator> Scan(std::shared_ptr<ScanOptions> options)

Scan returns an iterator of ScanTasks, each of which yields RecordBatches from this Fragment.

Note that batches yielded using this method will not be filtered and may not align with the Fragment’s schema. In particular, note that columns referenced by the filter may be present in yielded batches even if they are not projected (so that they are available when a filter is applied). Additionally, explicitly projected columns may be absent if they were not present in this fragment.

To receive a record batch stream which is fully filtered and projected, use Scanner.

class InMemoryDataset : public arrow::dataset::Dataset
#include <arrow/dataset/dataset.h>

A Source which yields fragments wrapping a stream of record batches.

The record batches must match the schema provided to the source at construction.

Public Functions

InMemoryDataset(std::shared_ptr<Schema> schema, std::shared_ptr<RecordBatchGenerator> get_batches)

Construct a dataset from a schema and a factory of record batch iterators.

InMemoryDataset(std::shared_ptr<Schema> schema, RecordBatchVector batches)

Convenience constructor taking a fixed list of batches.

InMemoryDataset(std::shared_ptr<Table> table)

Convenience constructor taking a Table.

std::string type_name() const

The name identifying the kind of Dataset.

Result<std::shared_ptr<Dataset>> ReplaceSchema(std::shared_ptr<Schema> schema) const

Return a copy of this Dataset with a different schema.

The copy will view the same Fragments. If the new schema is not compatible with the original dataset’s schema then an error will be raised.

class UnionDataset : public arrow::dataset::Dataset
#include <arrow/dataset/dataset.h>

A Dataset wrapping child Datasets.

Public Functions

std::string type_name() const

The name identifying the kind of Dataset.

Result<std::shared_ptr<Dataset>> ReplaceSchema(std::shared_ptr<Schema> schema) const

Return a copy of this Dataset with a different schema.

The copy will view the same Fragments. If the new schema is not compatible with the original dataset’s schema then an error will be raised.

Public Static Functions

static Result<std::shared_ptr<UnionDataset>> Make(std::shared_ptr<Schema> schema, DatasetVector children)

Construct a UnionDataset wrapping child Datasets.

Parameters
  • [in] schema: the schema of the resulting dataset.

  • [in] children: one or more child Datasets. Their schemas must be identical to schema.

class UnionDatasetFactory : public arrow::dataset::DatasetFactory
#include <arrow/dataset/discovery.h>

DatasetFactory provides a way to inspect/discover a Dataset’s expected schema before materialization.

Public Functions

const std::vector<std::shared_ptr<DatasetFactory>> &factories() const

Return the list of child DatasetFactory.

Result<std::vector<std::shared_ptr<Schema>>> InspectSchemas(InspectOptions options)

Get the schemas of the Datasets.

Instead of applying options globally, it applies at each child factory. This will not respect options.fragments exactly, but will respect the spirit of peeking the first fragments or all of them.

Result<std::shared_ptr<Dataset>> Finish(FinishOptions options)

Create a Dataset.

File System Datasets

struct FileSystemFactoryOptions
#include <arrow/dataset/discovery.h>

Public Members

PartitioningOrFactory partitioning = {Partitioning::Default()}

Either an explicit Partitioning or a PartitioningFactory to discover one.

If a factory is provided, it will be used to infer a schema for partition fields based on file and directory paths then construct a Partitioning. The default is a Partitioning which will yield no partition information.

The (explicit or discovered) partitioning will be applied to discovered files and the resulting partition information embedded in the Dataset.

std::string partition_base_dir

For the purposes of applying the partitioning, paths will be stripped of the partition_base_dir.

Files not matching the partition_base_dir prefix will be skipped for partition discovery. The ignored files will still be part of the Dataset, but will not have partition information.

Example: partition_base_dir = “/dataset”;

  • “/dataset/US/sales.csv” -> “US/sales.csv” will be given to the partitioning

  • ”/home/john/late_sales.csv” -> Will be ignored for partition discovery.

This is useful for partitioning which parses directory when ordering is important, e.g. DirectoryPartitioning.

bool exclude_invalid_files = false

Invalid files (via selector or explicitly) will be excluded by checking with the FileFormat::IsSupported method.

This will incur IO for each files in a serial and single threaded fashion. Disabling this feature will skip the IO, but unsupported files may be present in the Dataset (resulting in an error at scan time).

std::vector<std::string> selector_ignore_prefixes = {".", "_",}

When discovering from a Selector (and not from an explicit file list), ignore files and directories matching any of these prefixes.

Example (with selector = “/dataset/&zwj;**”): selector_ignore_prefixes = {“_”, “.DS_STORE” };

  • “/dataset/data.csv” -> not ignored

  • ”/dataset/_metadata” -> ignored

  • ”/dataset/.DS_STORE” -> ignored

  • ”/dataset/_hidden/dat” -> ignored

  • ”/dataset/nested/.DS_STORE” -> ignored

class FileSystemDatasetFactory : public arrow::dataset::DatasetFactory
#include <arrow/dataset/discovery.h>

FileSystemDatasetFactory creates a Dataset from a vector of fs::FileInfo or a fs::FileSelector.

Public Functions

Result<std::vector<std::shared_ptr<Schema>>> InspectSchemas(InspectOptions options)

Get the schemas of the Fragments and Partitioning.

Result<std::shared_ptr<Dataset>> Finish(FinishOptions options)

Create a Dataset with the given options.

Public Static Functions

static Result<std::shared_ptr<DatasetFactory>> Make(std::shared_ptr<fs::FileSystem> filesystem, const std::vector<std::string> &paths, std::shared_ptr<FileFormat> format, FileSystemFactoryOptions options)

Build a FileSystemDatasetFactory from an explicit list of paths.

Parameters

static Result<std::shared_ptr<DatasetFactory>> Make(std::shared_ptr<fs::FileSystem> filesystem, fs::FileSelector selector, std::shared_ptr<FileFormat> format, FileSystemFactoryOptions options)

Build a FileSystemDatasetFactory from a fs::FileSelector.

The selector will expand to a vector of FileInfo. The expansion/crawling is performed in this function call. Thus, the finalized Dataset is working with a snapshot of the filesystem. If options.partition_base_dir is not provided, it will be overwritten with selector.base_dir.

Parameters

static Result<std::shared_ptr<DatasetFactory>> Make(std::string uri, std::shared_ptr<FileFormat> format, FileSystemFactoryOptions options)

Build a FileSystemDatasetFactory from an uri including filesystem information.

Parameters

class FileSource
#include <arrow/dataset/file_base.h>

The path and filesystem where an actual file is located or a buffer which can be read like a file.

Public Functions

Compression::type compression() const

Return the type of raw compression on the file, if any.

const std::string &path() const

Return the file path, if any. Only valid when file source wraps a path.

const std::shared_ptr<fs::FileSystem> &filesystem() const

Return the filesystem, if any. Otherwise returns nullptr.

const std::shared_ptr<Buffer> &buffer() const

Return the buffer containing the file, if any. Otherwise returns nullptr.

Result<std::shared_ptr<io::RandomAccessFile>> Open() const

Get a RandomAccessFile which views this file source.

Result<std::shared_ptr<io::InputStream>> OpenCompressed(util::optional<Compression::type> compression = util::nullopt) const

Get an InputStream which views this file source (and decompresses if needed)

Parameters
  • [in] compression: If nullopt, guess the compression scheme from the filename, else decompress with the given codec

class FileFormat : public std::enable_shared_from_this<FileFormat>
#include <arrow/dataset/file_base.h>

Base class for file format implementation.

Subclassed by arrow::dataset::CsvFileFormat, arrow::dataset::IpcFileFormat, arrow::dataset::ParquetFileFormat

Public Functions

virtual std::string type_name() const = 0

The name identifying the kind of file format.

virtual Result<bool> IsSupported(const FileSource &source) const = 0

Indicate if the FileSource is supported/readable by this format.

virtual Result<std::shared_ptr<Schema>> Inspect(const FileSource &source) const = 0

Return the schema of the file if possible.

virtual Result<ScanTaskIterator> ScanFile(std::shared_ptr<ScanOptions> options, const std::shared_ptr<FileFragment> &file) const = 0

Open a FileFragment for scanning.

May populate lazy properties of the FileFragment.

virtual Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, Expression partition_expression, std::shared_ptr<Schema> physical_schema)

Open a fragment.

Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, Expression partition_expression)

Create a FileFragment for a FileSource.

Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, std::shared_ptr<Schema> physical_schema = NULLPTR)

Create a FileFragment for a FileSource.

virtual Result<std::shared_ptr<FileWriter>> MakeWriter(std::shared_ptr<io::OutputStream> destination, std::shared_ptr<Schema> schema, std::shared_ptr<FileWriteOptions> options) const = 0

Create a writer for this format.

virtual std::shared_ptr<FileWriteOptions> DefaultWriteOptions() = 0

Get default write options for this format.

Public Members

std::shared_ptr<FragmentScanOptions> default_fragment_scan_options

Options affecting how this format is scanned.

The options here can be overridden at scan time.

class FileFragment : public arrow::dataset::Fragment
#include <arrow/dataset/file_base.h>

A Fragment that is stored in a file with a known format.

Subclassed by arrow::dataset::ParquetFileFragment

Public Functions

Result<ScanTaskIterator> Scan(std::shared_ptr<ScanOptions> options)

Scan returns an iterator of ScanTasks, each of which yields RecordBatches from this Fragment.

Note that batches yielded using this method will not be filtered and may not align with the Fragment’s schema. In particular, note that columns referenced by the filter may be present in yielded batches even if they are not projected (so that they are available when a filter is applied). Additionally, explicitly projected columns may be absent if they were not present in this fragment.

To receive a record batch stream which is fully filtered and projected, use Scanner.

class FileSystemDataset : public arrow::dataset::Dataset
#include <arrow/dataset/file_base.h>

A Dataset of FileFragments.

A FileSystemDataset is composed of one or more FileFragment. The fragments are independent and don’t need to share the same format and/or filesystem.

Public Functions

std::string type_name() const

Return the type name of the dataset.

Result<std::shared_ptr<Dataset>> ReplaceSchema(std::shared_ptr<Schema> schema) const

Replace the schema of the dataset.

std::vector<std::string> files() const

Return the path of files.

const std::shared_ptr<FileFormat> &format() const

Return the format.

const std::shared_ptr<fs::FileSystem> &filesystem() const

Return the filesystem. May be nullptr if the fragments wrap buffers.

Public Static Functions

static Result<std::shared_ptr<FileSystemDataset>> Make(std::shared_ptr<Schema> schema, Expression root_partition, std::shared_ptr<FileFormat> format, std::shared_ptr<fs::FileSystem> filesystem, std::vector<std::shared_ptr<FileFragment>> fragments)

Create a FileSystemDataset.

Note that fragments wrapping files resident in differing filesystems are not permitted; to work with multiple filesystems use a

UnionDataset.
Parameters
  • [in] schema: the schema of the dataset

  • [in] root_partition: the partition expression of the dataset

  • [in] format: the format of each FileFragment.

  • [in] filesystem: the filesystem of each FileFragment, or nullptr if the fragments wrap buffers.

  • [in] fragments: list of fragments to create the dataset from.

Return

A constructed dataset.

static Status Write(const FileSystemDatasetWriteOptions &write_options, std::shared_ptr<Scanner> scanner)

Write a dataset.

class FileWriteOptions
#include <arrow/dataset/file_base.h>

Options for writing a file of this format.

Subclassed by arrow::dataset::IpcFileWriteOptions, arrow::dataset::ParquetFileWriteOptions

class FileWriter
#include <arrow/dataset/file_base.h>

A writer for this format.

Subclassed by arrow::dataset::IpcFileWriter, arrow::dataset::ParquetFileWriter

Public Functions

virtual Status Write(const std::shared_ptr<RecordBatch> &batch) = 0

Write the given batch.

Status Write(RecordBatchReader *batches)

Write all batches from the reader.

virtual Status Finish()

Indicate that writing is done.

struct FileSystemDatasetWriteOptions
#include <arrow/dataset/file_base.h>

Options for writing a dataset.

Public Members

std::shared_ptr<FileWriteOptions> file_write_options

Options for individual fragment writing.

std::shared_ptr<fs::FileSystem> filesystem

FileSystem into which a dataset will be written.

std::string base_dir

Root directory into which the dataset will be written.

std::shared_ptr<Partitioning> partitioning

Partitioning used to generate fragment paths.

int max_partitions = 1024

Maximum number of partitions any batch may be written into, default is 1K.

std::string basename_template

Template string used to generate fragment basenames.

{i} will be replaced by an auto incremented integer.

File Formats

constexpr char arrow::dataset::kIpcTypeName[] = "ipc"
constexpr char arrow::dataset::kParquetTypeName[] = "parquet"
class CsvFileFormat : public arrow::dataset::FileFormat
#include <arrow/dataset/file_csv.h>

A FileFormat implementation that reads from and writes to Csv files.

Public Functions

std::string type_name() const

The name identifying the kind of file format.

Result<bool> IsSupported(const FileSource &source) const

Indicate if the FileSource is supported/readable by this format.

Result<std::shared_ptr<Schema>> Inspect(const FileSource &source) const

Return the schema of the file if possible.

Result<ScanTaskIterator> ScanFile(std::shared_ptr<ScanOptions> options, const std::shared_ptr<FileFragment> &fragment) const

Open a file for scanning.

Result<std::shared_ptr<FileWriter>> MakeWriter(std::shared_ptr<io::OutputStream> destination, std::shared_ptr<Schema> schema, std::shared_ptr<FileWriteOptions> options) const

Create a writer for this format.

std::shared_ptr<FileWriteOptions> DefaultWriteOptions()

Get default write options for this format.

Public Members

csv::ParseOptions parse_options = csv::ParseOptions::Defaults()

Options affecting the parsing of CSV files.

struct CsvFragmentScanOptions : public arrow::dataset::FragmentScanOptions
#include <arrow/dataset/file_csv.h>

Per-scan options for CSV fragments.

Public Members

csv::ConvertOptions convert_options = csv::ConvertOptions::Defaults()

CSV conversion options.

csv::ReadOptions read_options = csv::ReadOptions::Defaults()

CSV reading options.

Note that use_threads is always ignored.

class IpcFileFormat : public arrow::dataset::FileFormat
#include <arrow/dataset/file_ipc.h>

A FileFormat implementation that reads from and writes to Ipc files.

Public Functions

std::string type_name() const

The name identifying the kind of file format.

Result<bool> IsSupported(const FileSource &source) const

Indicate if the FileSource is supported/readable by this format.

Result<std::shared_ptr<Schema>> Inspect(const FileSource &source) const

Return the schema of the file if possible.

Result<ScanTaskIterator> ScanFile(std::shared_ptr<ScanOptions> options, const std::shared_ptr<FileFragment> &fragment) const

Open a file for scanning.

Result<std::shared_ptr<FileWriter>> MakeWriter(std::shared_ptr<io::OutputStream> destination, std::shared_ptr<Schema> schema, std::shared_ptr<FileWriteOptions> options) const

Create a writer for this format.

std::shared_ptr<FileWriteOptions> DefaultWriteOptions()

Get default write options for this format.

class IpcFragmentScanOptions : public arrow::dataset::FragmentScanOptions
#include <arrow/dataset/file_ipc.h>

Per-scan options for IPC fragments.

Public Members

std::shared_ptr<ipc::IpcReadOptions> options

Options passed to the IPC file reader.

included_fields, memory_pool, and use_threads are ignored.

class IpcFileWriteOptions : public arrow::dataset::FileWriteOptions
#include <arrow/dataset/file_ipc.h>

Public Members

std::shared_ptr<ipc::IpcWriteOptions> options

Options passed to ipc::MakeFileWriter. use_threads is ignored.

std::shared_ptr<const KeyValueMetadata> metadata

custom_metadata written to the file’s footer

class IpcFileWriter : public arrow::dataset::FileWriter
#include <arrow/dataset/file_ipc.h>

Public Functions

Status Write(const std::shared_ptr<RecordBatch> &batch)

Write the given batch.

class ParquetFileFormat : public arrow::dataset::FileFormat
#include <arrow/dataset/file_parquet.h>

A FileFormat implementation that reads from Parquet files.

Public Functions

ParquetFileFormat(const parquet::ReaderProperties &reader_properties)

Convenience constructor which copies properties from a parquet::ReaderProperties.

memory_pool will be ignored.

std::string type_name() const

The name identifying the kind of file format.

Result<bool> IsSupported(const FileSource &source) const

Indicate if the FileSource is supported/readable by this format.

Result<std::shared_ptr<Schema>> Inspect(const FileSource &source) const

Return the schema of the file if possible.

Result<ScanTaskIterator> ScanFile(std::shared_ptr<ScanOptions> options, const std::shared_ptr<FileFragment> &file) const

Open a file for scanning.

Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, Expression partition_expression, std::shared_ptr<Schema> physical_schema)

Create a Fragment targeting all RowGroups.

Result<std::shared_ptr<ParquetFileFragment>> MakeFragment(FileSource source, Expression partition_expression, std::shared_ptr<Schema> physical_schema, std::vector<int> row_groups)

Create a Fragment, restricted to the specified row groups.

Result<std::unique_ptr<parquet::arrow::FileReader>> GetReader(const FileSource &source, ScanOptions * = NULLPTR) const

Return a FileReader on the given source.

Result<std::shared_ptr<FileWriter>> MakeWriter(std::shared_ptr<io::OutputStream> destination, std::shared_ptr<Schema> schema, std::shared_ptr<FileWriteOptions> options) const

Create a writer for this format.

std::shared_ptr<FileWriteOptions> DefaultWriteOptions()

Get default write options for this format.

virtual Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, Expression partition_expression, std::shared_ptr<Schema> physical_schema)

Open a fragment.

Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, Expression partition_expression)

Create a FileFragment for a FileSource.

Result<std::shared_ptr<FileFragment>> MakeFragment(FileSource source, std::shared_ptr<Schema> physical_schema = NULLPTR)

Create a FileFragment for a FileSource.

class ParquetFileFragment : public arrow::dataset::FileFragment
#include <arrow/dataset/file_parquet.h>

A FileFragment with parquet logic.

ParquetFileFragment provides a lazy (with respect to IO) interface to scan parquet files. Any heavy IO calls are deferred to the Scan() method.

The caller can provide an optional list of selected RowGroups to limit the number of scanned RowGroups, or to partition the scans across multiple threads.

Metadata can be explicitly provided, enabling pushdown predicate benefits without the potentially heavy IO of loading Metadata from the file system. This can induce significant performance boost when scanning high latency file systems.

Public Functions

const std::vector<int> &row_groups() const

Return the RowGroups selected by this fragment.

const std::shared_ptr<parquet::FileMetaData> &metadata() const

Return the FileMetaData associated with this fragment.

Status EnsureCompleteMetadata(parquet::arrow::FileReader *reader = NULLPTR)

Ensure this fragment’s FileMetaData is in memory.

Result<std::shared_ptr<Fragment>> Subset(Expression predicate)

Return fragment which selects a filtered subset of this fragment’s RowGroups.

class ParquetFragmentScanOptions : public arrow::dataset::FragmentScanOptions
#include <arrow/dataset/file_parquet.h>

Per-scan options for Parquet fragments.

Public Members

std::shared_ptr<parquet::ReaderProperties> reader_properties

Reader properties.

Not all properties are respected: memory_pool comes from ScanOptions.

std::shared_ptr<parquet::ArrowReaderProperties> arrow_reader_properties

Arrow reader properties.

Not all properties are respected: batch_size comes from ScanOptions, and use_threads will be overridden based on enable_parallel_column_conversion. Additionally, dictionary columns come from ParquetFileFormat::ReaderOptions::dict_columns.

bool enable_parallel_column_conversion = false

EXPERIMENTAL: Parallelize conversion across columns.

This option is ignored if a scan is already parallelized across input files to avoid thread contention. This option will be removed after support is added for simultaneous parallelization across files and columns.

class ParquetFileWriteOptions : public arrow::dataset::FileWriteOptions
#include <arrow/dataset/file_parquet.h>

Public Members

std::shared_ptr<parquet::WriterProperties> writer_properties

Parquet writer properties.

std::shared_ptr<parquet::ArrowWriterProperties> arrow_writer_properties

Parquet Arrow writer properties.

class ParquetFileWriter : public arrow::dataset::FileWriter
#include <arrow/dataset/file_parquet.h>

Public Functions

Status Write(const std::shared_ptr<RecordBatch> &batch)

Write the given batch.

struct ParquetFactoryOptions
#include <arrow/dataset/file_parquet.h>

Options for making a FileSystemDataset from a Parquet _metadata file.

Public Members

PartitioningOrFactory partitioning = {Partitioning::Default()}

Either an explicit Partitioning or a PartitioningFactory to discover one.

If a factory is provided, it will be used to infer a schema for partition fields based on file and directory paths then construct a Partitioning. The default is a Partitioning which will yield no partition information.

The (explicit or discovered) partitioning will be applied to discovered files and the resulting partition information embedded in the Dataset.

std::string partition_base_dir

For the purposes of applying the partitioning, paths will be stripped of the partition_base_dir.

Files not matching the partition_base_dir prefix will be skipped for partition discovery. The ignored files will still be part of the Dataset, but will not have partition information.

Example: partition_base_dir = “/dataset”;

  • “/dataset/US/sales.csv” -> “US/sales.csv” will be given to the partitioning

  • ”/home/john/late_sales.csv” -> Will be ignored for partition discovery.

This is useful for partitioning which parses directory when ordering is important, e.g. DirectoryPartitioning.

bool validate_column_chunk_paths = false

Assert that all ColumnChunk paths are consistent.

The parquet spec allows for ColumnChunk data to be stored in multiple files, but ParquetDatasetFactory supports only a single file with all ColumnChunk data. If this flag is set construction of a ParquetDatasetFactory will raise an error if ColumnChunk data is not resident in a single file.

class ParquetDatasetFactory : public arrow::dataset::DatasetFactory
#include <arrow/dataset/file_parquet.h>

Create FileSystemDataset from custom _metadata cache file.

Dask and other systems will generate a cache metadata file by concatenating the RowGroupMetaData of multiple parquet files into a single parquet file that only contains metadata and no ColumnChunk data.

ParquetDatasetFactory creates a FileSystemDataset composed of ParquetFileFragment where each fragment is pre-populated with the exact number of row groups and statistics for each columns.

Public Functions

Result<std::vector<std::shared_ptr<Schema>>> InspectSchemas(InspectOptions options)

Get the schemas of the Fragments and Partitioning.

Result<std::shared_ptr<Dataset>> Finish(FinishOptions options)

Create a Dataset with the given options.

Public Static Functions

static Result<std::shared_ptr<DatasetFactory>> Make(const std::string &metadata_path, std::shared_ptr<fs::FileSystem> filesystem, std::shared_ptr<ParquetFileFormat> format, ParquetFactoryOptions options)

Create a ParquetDatasetFactory from a metadata path.

The metadata_path will be read from filesystem. Each RowGroup contained in the metadata file will be relative to dirname(metadata_path).

Parameters
  • [in] metadata_path: path of the metadata parquet file

  • [in] filesystem: from which to open/read the path

  • [in] format: to read the file with.

  • [in] options: see ParquetFactoryOptions

static Result<std::shared_ptr<DatasetFactory>> Make(const FileSource &metadata, const std::string &base_path, std::shared_ptr<fs::FileSystem> filesystem, std::shared_ptr<ParquetFileFormat> format, ParquetFactoryOptions options)

Create a ParquetDatasetFactory from a metadata source.

Similar to the previous Make definition, but the metadata can be a Buffer and the base_path is explicited instead of inferred from the metadata path.

Parameters
  • [in] metadata: source to open the metadata parquet file from

  • [in] base_path: used as the prefix of every parquet files referenced

  • [in] filesystem: from which to read the files referenced.

  • [in] format: to read the file with.

  • [in] options: see ParquetFactoryOptions