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/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.0.tar.gz (520.2 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.0-cp36-abi3-win_amd64.whl (10.1 MB view details)

Uploaded CPython 3.6+Windows x86-64

polars-0.10.0-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl (9.7 MB view details)

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

polars-0.10.0-cp36-abi3-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl (17.4 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.0-cp36-abi3-macosx_10_7_x86_64.whl (9.6 MB view details)

Uploaded CPython 3.6+macOS 10.7+ x86-64

File details

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

File metadata

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

File hashes

Hashes for polars-0.10.0.tar.gz
Algorithm Hash digest
SHA256 5afd8009d511c20577e38340ea6a5531804e0f6d6d66632052b84be757217e8a
MD5 fe755f0d33b42b8a7675cb6c5b284dc2
BLAKE2b-256 d72474c99bd1cfab546e46f63aa0005ab2bc5dc523b07936c88c525249b7d491

See more details on using hashes here.

File details

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

File metadata

  • Download URL: polars-0.10.0-cp36-abi3-win_amd64.whl
  • Upload date:
  • Size: 10.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.10.0-cp36-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 cb998af4a3b06cd0324b446f9184901c5b933192119715987da1ba10ada38c6b
MD5 9220c1b8770634ccf8c6db10b8f8eec1
BLAKE2b-256 0d379e0b594eea075bf67d381bd8af35b5c384366c69ce5669d7cf7b3b576378

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polars-0.10.0-cp36-abi3-manylinux_2_12_x86_64.manylinux2010_x86_64.whl
Algorithm Hash digest
SHA256 6a9252a1ab5c286372c4a156de03b80c35c8f21ff328dde12e7aacba407743f5
MD5 047ab04107379e1f9d4bbb282be31aa5
BLAKE2b-256 7dc91d08b3ebd1b0f356973882e902710d384fc4ca612bdda058cbc8c9174091

See more details on using hashes here.

File details

Details for the file polars-0.10.0-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.0-cp36-abi3-macosx_10_9_x86_64.macosx_11_0_arm64.macosx_10_9_universal2.whl
Algorithm Hash digest
SHA256 db6e1427753001e1a218c8ad9d39c81e73e9657be2df8f3863cfbb0c3c819fe7
MD5 36edc4b29bf16462cc4510eb896b7181
BLAKE2b-256 3adc60320bd34d0aaecfc063a3c9524ad67563496ef2dd74c2c4adb130abafd6

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for polars-0.10.0-cp36-abi3-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 38c9bd190a280a31da2005cd5aaf584bf0b9ad0ca20a7535e8149a5ab7cb434e
MD5 252905ba978c9154becd248c74952fec
BLAKE2b-256 0941ef370ecc1af7fe1c3bd90ab8fd06accfed25370cec041fa21fdc3c610810

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