Skip to content
forked from apache/arrow

Apache Arrow is a columnar in-memory analytics layer designed to accelerate big data. It houses a set of canonical in-memory representations of flat and hierarchical data along with multiple language-bindings for structure manipulation. It also provides IPC and common algorithm implementations.

License

Notifications You must be signed in to change notification settings

jianlirong/arrow

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

Folders and files

NameName
Last commit message
Last commit date

Latest commit

e03628a · Aug 4, 2020
Jul 30, 2020
Aug 4, 2020
Jul 30, 2020
Aug 4, 2020
Jul 28, 2020
Aug 4, 2020
Jul 28, 2020
Jul 12, 2020
Aug 4, 2020
Aug 4, 2020
Jul 28, 2020
Jul 28, 2020
Aug 3, 2020
Aug 4, 2020
Aug 4, 2020
Aug 4, 2020
Jul 16, 2020
Apr 20, 2020
Sep 26, 2018
Jan 10, 2020
Sep 26, 2018
Mar 12, 2020
Jul 30, 2020
Jun 5, 2020
Jun 12, 2019
May 6, 2020
Feb 8, 2019
Sep 19, 2019
Mar 18, 2019
Jun 23, 2017
Jul 2, 2020
Jul 20, 2020
Dec 15, 2018
Jan 3, 2020
Jul 10, 2020
Jul 15, 2019
Jun 11, 2020
May 15, 2020
Feb 11, 2019
Jul 30, 2020
Aug 18, 2016
Mar 18, 2020

Repository files navigation

Apache Arrow

Build Status Coverage Status 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 a number of 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 columnar in-memory analytics layer designed to accelerate big data. It houses a set of canonical in-memory representations of flat and hierarchical data along with multiple language-bindings for structure manipulation. It also provides IPC and common algorithm implementations.

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 45.0%
  • Java 14.5%
  • Rust 9.7%
  • Python 9.6%
  • TypeScript 3.8%
  • Ruby 3.5%
  • Other 13.9%