Skip to content
forked from apache/arrow

Apache Arrow is a cross-language development platform for in-memory data. It specifies a standardized language-independent columnar memory format for flat and hierarchical data, organized for efficient analytic operations on modern hardware. It also provides computational libraries and zero-copy streaming messaging and interprocess communication…

License

Notifications You must be signed in to change notification settings

o-shevchenko/arrow

This branch is 1499 commits behind apache/arrow:main.

Folders and files

NameName
Last commit message
Last commit date
Apr 23, 2024
Mar 22, 2024
Apr 23, 2024
Apr 23, 2024
Apr 23, 2024
Apr 23, 2024
Apr 20, 2024
Apr 20, 2024
Apr 17, 2024
Apr 23, 2024
Apr 23, 2024
Apr 20, 2024
Apr 20, 2024
Apr 20, 2024
Apr 23, 2024
Apr 20, 2024
Jan 27, 2024
Apr 11, 2024
Mar 21, 2024
Dec 2, 2021
Jun 19, 2023
Sep 26, 2018
May 9, 2022
Aug 12, 2022
Apr 15, 2024
Nov 14, 2023
Mar 22, 2024
Feb 8, 2019
Mar 11, 2024
Mar 28, 2024
Jun 23, 2017
Nov 29, 2023
Dec 15, 2018
Dec 11, 2023
Apr 2, 2024
Jan 2, 2024
Oct 18, 2023
Mar 20, 2024
Nov 29, 2023
Apr 15, 2024
Aug 18, 2016

Repository files navigation

Apache Arrow

Fuzzing Status License Twitter Follow

Powering In-Memory Analytics

Apache Arrow is a development platform for in-memory analytics. It contains a set of technologies that enable big data systems to process and move data fast.

Major components of the project include:

Arrow is an Apache Software Foundation project. Learn more at arrow.apache.org.

What's in the Arrow libraries?

The reference Arrow libraries contain many distinct software components:

  • Columnar vector and table-like containers (similar to data frames) supporting flat or nested types
  • Fast, language agnostic metadata messaging layer (using Google's Flatbuffers library)
  • Reference-counted off-heap buffer memory management, for zero-copy memory sharing and handling memory-mapped files
  • IO interfaces to local and remote filesystems
  • Self-describing binary wire formats (streaming and batch/file-like) for remote procedure calls (RPC) and interprocess communication (IPC)
  • Integration tests for verifying binary compatibility between the implementations (e.g. sending data from Java to C++)
  • Conversions to and from other in-memory data structures
  • Readers and writers for various widely-used file formats (such as Parquet, CSV)

Implementation status

The official Arrow libraries in this repository are in different stages of implementing the Arrow format and related features. See our current feature matrix on git main.

How to Contribute

Please read our latest project contribution guide.

Getting involved

Even if you do not plan to contribute to Apache Arrow itself or Arrow integrations in other projects, we'd be happy to have you involved:

About

Apache Arrow is a cross-language development platform for in-memory data. It specifies a standardized language-independent columnar memory format for flat and hierarchical data, organized for efficient analytic operations on modern hardware. It also provides computational libraries and zero-copy streaming messaging and interprocess communication…

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 49.1%
  • Java 13.5%
  • Go 10.1%
  • Python 5.6%
  • Cython 3.1%
  • Ruby 3.1%
  • Other 15.5%