Skip to content
/ arrow Public
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

czxrrr/arrow

This branch is 3 commits ahead of, 7293 commits behind apache/arrow:main.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6f853ed · Sep 23, 2021
Sep 22, 2021
Sep 18, 2021
Sep 22, 2021
Sep 22, 2021
Aug 9, 2021
Sep 22, 2021
Sep 22, 2021
Sep 21, 2021
Aug 31, 2021
Sep 22, 2021
Sep 21, 2021
Jul 30, 2021
May 1, 2021
Jul 28, 2021
Sep 22, 2021
Sep 21, 2021
Sep 21, 2021
Sep 2, 2021
Jun 12, 2021
Sep 26, 2018
Jan 10, 2020
Sep 26, 2018
Mar 12, 2020
Jun 23, 2021
Sep 22, 2021
Sep 21, 2021
May 6, 2020
Feb 8, 2019
Sep 19, 2019
Jun 23, 2021
Jun 23, 2017
Aug 18, 2021
Jan 18, 2021
Dec 15, 2018
Apr 4, 2021
Aug 19, 2021
Jul 15, 2019
May 8, 2021
May 15, 2020
Jun 23, 2021
Sep 22, 2021
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 master.

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++ 51.2%
  • Java 13.6%
  • Python 6.5%
  • Go 5.2%
  • Ruby 3.7%
  • TypeScript 3.1%
  • Other 16.7%