Skip to main content

No project description provided

Project description

Polars

rust docs Build and test Gitter

Blazingly fast DataFrames in Rust & Python

Polars is a blazingly fast DataFrames library implemented in Rust using Apache Arrow(2) as memory model.

  • Lazy | eager execution
  • Multi-threaded
  • SIMD
  • Query optimization
  • Powerful expression API
  • Rust | Python | ...

To learn more, read the User Guide.

>>> df = pl.DataFrame(
    {
        "A": [1, 2, 3, 4, 5],
        "fruits": ["banana", "banana", "apple", "apple", "banana"],
        "B": [5, 4, 3, 2, 1],
        "cars": ["beetle", "audi", "beetle", "beetle", "beetle"],
    }
)

# embarrassingly parallel execution
# very expressive query language
>>> (df
    .sort("fruits")
    .select([
    "fruits",
    "cars",
    lit("fruits").alias("literal_string_fruits"),
    col("B").filter(col("cars") == "beetle").sum(),
    col("A").filter(col("B") > 2).sum().over("cars").alias("sum_A_by_cars"),       # groups by "cars"
    col("A").sum().over("fruits").alias("sum_A_by_fruits"),                        # groups by "fruits"
    col("A").reverse().over("fruits").flatten().alias("rev_A_by_fruits"),          # groups by "fruits
    col("A").sort_by("B").over("fruits").flatten().alias("sort_A_by_B_by_fruits")  # groups by "fruits"
]))
shape: (5, 8)
âŒâ”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”¬â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”
│ fruits   ┆ cars     ┆ literal_stri ┆ B   ┆ sum_A_by_ca ┆ sum_A_by_fr ┆ rev_A_by_fr ┆ sort_A_by_B │
│ ---      ┆ ---      ┆ ng_fruits    ┆ --- ┆ rs          ┆ uits        ┆ uits        ┆ _by_fruits  │
│ str      ┆ str      ┆ ---          ┆ i64 ┆ ---         ┆ ---         ┆ ---         ┆ ---         │
│          ┆          ┆ str          ┆     ┆ i64         ┆ i64         ┆ i64         ┆ i64         │
âžâ•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•â•â•â•âªâ•â•â•â•â•â•â•â•â•â•â•â•â•â•¡
│ "apple"  ┆ "beetle" ┆ "fruits"     ┆ 11  ┆ 4           ┆ 7           ┆ 4           ┆ 4           │
âœâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¤
│ "apple"  ┆ "beetle" ┆ "fruits"     ┆ 11  ┆ 4           ┆ 7           ┆ 3           ┆ 3           │
âœâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¤
│ "banana" ┆ "beetle" ┆ "fruits"     ┆ 11  ┆ 4           ┆ 8           ┆ 5           ┆ 5           │
âœâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¤
│ "banana" ┆ "audi"   ┆ "fruits"     ┆ 11  ┆ 2           ┆ 8           ┆ 2           ┆ 2           │
âœâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¼âŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâŒâ”¤
│ "banana" ┆ "beetle" ┆ "fruits"     ┆ 11  ┆ 4           ┆ 8           ┆ 1           ┆ 1           │
└──────────┴──────────┴──────────────┴─────┴─────────────┴─────────────┴─────────────┴─────────────┘

Performance 🚀🚀

Polars is very fast, and in fact is one of the best performing solutions available. See the results in h2oai's db-benchmark.

Rust setup

You can take latest release from crates.io, or if you want to use the latest features/ performance improvements point to the master branch of this repo.

polars = {git = "https://github.com/ritchie46/polars", rev = "<optional git tag>" } 

Rust version

Required Rust version >=1.52

Python users read this!

Polars is currently transitioning from py-polars to polars. Some docs may still refer the old name.

Install the latest polars version with: $ pip3 install polars

Documentation

Want to know about all the features Polars support? Read the docs!

Rust

Python

Contribution

Want to contribute? Read our contribution guideline.

[Python] compile py-polars from source

If you want a bleeding edge release or maximal performance you should compile py-polars from source.

This can be done by going through the following steps in sequence:

  1. install the latest rust compiler
  2. $ pip3 install maturin
  3. Choose any of:
  • Very long compile times, fastest binary: $ cd py-polars && maturin develop --rustc-extra-args="-C target-cpu=native" --release
  • Shorter compile times, fast binary: $ cd py-polars && maturin develop --rustc-extra-args="-C codegen-units=16 -C lto=thin -C target-cpu=native" --release

Note that the Rust crate implementing the Python bindings is called py-polars to distinguish from the wrapped Rust crate polars itself. However, both the Python package and the Python module are named polars, so you can pip install polars and import polars (previously, these were called py-polars and pypolars).

Arrow2

Polars has a fully functional arrow2 branch and will ship the python binaries from this branch. Arrow2 is a faster and safer implementation of the arrow spec. Arrow2 also has a more granular code base, helping to reduce the compiler bloat.

Acknowledgements

Development of Polars is proudly powered by

Xomnia

Sponsors

Project details


Release history Release notifications | RSS feed

This version

0.9.3

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

polars-0.9.3.tar.gz (503.1 kB view details)

Uploaded Source

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

polars-0.9.3-cp36-abi3-win_amd64.whl (11.1 MB view details)

Uploaded CPython 3.6+Windows x86-64

polars-0.9.3-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (10.6 MB view details)

Uploaded CPython 3.6+manylinux: glibc 2.12+ x86-64

polars-0.9.3-cp36-abi3-macosx_10_7_x86_64.whl (10.4 MB view details)

Uploaded CPython 3.6+macOS 10.7+ x86-64

File details

Details for the file polars-0.9.3.tar.gz.

File metadata

  • Download URL: polars-0.9.3.tar.gz
  • Upload date:
  • Size: 503.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/0.11.3

File hashes

Hashes for polars-0.9.3.tar.gz
Algorithm Hash digest
SHA256 ac614663733b37739d0691f7f69cf4669825820d89ab2bb978b29714b1f4b7aa
MD5 9b6665a2cb1fb1b2baa17fbda8128ab7
BLAKE2b-256 d92c3cdc3fd368e73abcf08c674152dfb5556b56635bae2514bb16c0b6f08ba2

See more details on using hashes here.

File details

Details for the file polars-0.9.3-cp36-abi3-win_amd64.whl.

File metadata

  • Download URL: polars-0.9.3-cp36-abi3-win_amd64.whl
  • Upload date:
  • Size: 11.1 MB
  • Tags: CPython 3.6+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: maturin/0.11.0

File hashes

Hashes for polars-0.9.3-cp36-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 a1b6019af0fa9e71feca8582ee6ff64ff47da43634b95ee6faeb5c9e6319007f
MD5 a5aac0dfbde1454e62475654aab43ea8
BLAKE2b-256 a5472b8d472564ed268136b1f6081e591efc3a1d184513a68529973b4eaef03b

See more details on using hashes here.

File details

Details for the file polars-0.9.3-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl.

File metadata

File hashes

Hashes for polars-0.9.3-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 f3f6ebc2f3645c251c89af5f4a7ca1e2448f53b3ad193488a2450db5d700bdc5
MD5 f7f5bddd204889b8238a7bbe402ddaf5
BLAKE2b-256 349f359dc7a8f3fd3c367cfc00e849f6d3ac1ee20bf58d32a1cda8a30c9b3819

See more details on using hashes here.

File details

Details for the file polars-0.9.3-cp36-abi3-macosx_10_7_x86_64.whl.

File metadata

File hashes

Hashes for polars-0.9.3-cp36-abi3-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 655f85aa1ba509fa9a73b39f2628c5880888d59170c765eec803553f750499d0
MD5 e70f1edcdeb846be59e548892ea217e5
BLAKE2b-256 e10225270c8ef5f52892e56d32935e604175b47e5990a4a9d587ac40463400a6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page