Skip to main content

No project description provided

Project description

Polars

rust docs Build and test PyPI Latest Release

Python Documentation | Rust Documentation | Discord | StackOverflow

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.

>>> import polars as pl
>>> 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",
    pl.lit("fruits").alias("literal_string_fruits"),
    pl.col("B").filter(pl.col("cars") == "beetle").sum(),
    pl.col("A").filter(pl.col("B") > 2).sum().over("cars").alias("sum_A_by_cars"),    # groups by "cars"
    pl.col("A").sum().over("fruits").alias("sum_A_by_fruits"),                        # groups by "fruits"
    pl.col("A").reverse().over("fruits").flatten().alias("rev_A_by_fruits"),          # groups by "fruits
    pl.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/pola-rs/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 transitioned to arrow2. 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. There is still a maintained arrow-rs branch for users who want to use another backend.

Acknowledgements

Development of Polars is proudly powered by

Xomnia

Sponsors

Project details


Release history Release notifications | RSS feed

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.10.25.tar.gz (593.5 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.10.25-cp36-abi3-win_amd64.whl (10.3 MB view details)

Uploaded CPython 3.6+Windows x86-64

polars-0.10.25-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (9.9 MB view details)

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

polars-0.10.25-cp36-abi3-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl (17.6 MB view details)

Uploaded CPython 3.6+macOS 10.9+ universal2 (ARM64, x86-64)macOS 10.9+ x86-64macOS 11.0+ ARM64

polars-0.10.25-cp36-abi3-macosx_10_7_x86_64.whl (9.7 MB view details)

Uploaded CPython 3.6+macOS 10.7+ x86-64

File details

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

File metadata

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

File hashes

Hashes for polars-0.10.25.tar.gz
Algorithm Hash digest
SHA256 8f173236990aac3db8dcc99a986003b66aad2f93365004d1c60d2aa38404629a
MD5 73e846844f042118d11a915154dac9d5
BLAKE2b-256 a893b24918288251d4ce0425829b65cfc77cad5a5c9b7fde6d5267cf1b7dc203

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for polars-0.10.25-cp36-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 a31871e80eea0bbf4d0696729d21e54b9fa495582ae4651a8250339d57ba694a
MD5 d1dd5d459bdfd324bdfba90d78cb5628
BLAKE2b-256 e9678de07f6bd627ca44134b577c94d2919b9d693c1a62883e566d38daaf363a

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polars-0.10.25-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 25dab31615f9e058b0c9e3a36907f8f7e413cf526f17a0d27f3aaf1d0d8fe057
MD5 89de1d44c2de30cac89b6ec093bda7d8
BLAKE2b-256 a4c438a7babab4be08baf21c448837a3e423ba20ed54e95e100648de97a32578

See more details on using hashes here.

File details

Details for the file polars-0.10.25-cp36-abi3-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl.

File metadata

File hashes

Hashes for polars-0.10.25-cp36-abi3-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 37bcec387580c90da7097e620b73400031afe857e4a485557caceba2e91fc491
MD5 f46fbd41e19f98b1169429540fb1f393
BLAKE2b-256 0b4084ea6409152ec08490b868e46ca6fb6a22234f2b75170a0e2979ceb0df63

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polars-0.10.25-cp36-abi3-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 d441ca6b4472e312cdf57bd2cd7e19a62caf2d20c32f4a042cc6f47f515f35d5
MD5 b6d24acc00d69a8ea73ac2672ccec280
BLAKE2b-256 bb4a57a4a6167ca6e47490d2f480f9c42646d94919782b3e79f94339cbbdd4f3

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