Name | polars-u64-idx JSON |
Version |
1.33.0
JSON |
| download |
home_page | None |
Summary | Blazingly fast DataFrame library |
upload_time | 2025-09-01 16:32:50 |
maintainer | None |
docs_url | None |
author | None |
requires_python | >=3.9 |
license | None |
keywords |
dataframe
arrow
out-of-core
|
VCS |
 |
bugtrack_url |
|
requirements |
No requirements were recorded.
|
Travis-CI |
No Travis.
|
coveralls test coverage |
No coveralls.
|
<h1 align="center">
<a href="https://pola.rs">
<img src="https://raw.githubusercontent.com/pola-rs/polars-static/master/banner/polars_github_banner.svg" alt="Polars logo">
</a>
</h1>
<div align="center">
<a href="https://crates.io/crates/polars">
<img src="https://img.shields.io/crates/v/polars.svg" alt="crates.io Latest Release"/>
</a>
<a href="https://pypi.org/project/polars/">
<img src="https://img.shields.io/pypi/v/polars.svg" alt="PyPi Latest Release"/>
</a>
<a href="https://www.npmjs.com/package/nodejs-polars">
<img src="https://img.shields.io/npm/v/nodejs-polars.svg" alt="NPM Latest Release"/>
</a>
<a href="https://community.r-multiverse.org/polars">
<img src="https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fcommunity.r-multiverse.org%2Fapi%2Fpackages%2Fpolars&query=%24.Version&label=r-multiverse" alt="R-multiverse Latest Release"/>
</a>
<a href="https://doi.org/10.5281/zenodo.7697217">
<img src="https://zenodo.org/badge/DOI/10.5281/zenodo.7697217.svg" alt="DOI Latest Release"/>
</a>
</div>
<p align="center">
<b>Documentation</b>:
<a href="https://docs.pola.rs/api/python/stable/reference/index.html">Python</a>
-
<a href="https://docs.rs/polars/latest/polars/">Rust</a>
-
<a href="https://pola-rs.github.io/nodejs-polars/index.html">Node.js</a>
-
<a href="https://pola-rs.github.io/r-polars/index.html">R</a>
|
<b>StackOverflow</b>:
<a href="https://stackoverflow.com/questions/tagged/python-polars">Python</a>
-
<a href="https://stackoverflow.com/questions/tagged/rust-polars">Rust</a>
-
<a href="https://stackoverflow.com/questions/tagged/nodejs-polars">Node.js</a>
-
<a href="https://stackoverflow.com/questions/tagged/r-polars">R</a>
|
<a href="https://docs.pola.rs/">User guide</a>
|
<a href="https://discord.gg/4UfP5cfBE7">Discord</a>
</p>
## Polars: Blazingly fast DataFrames in Rust, Python, Node.js, R, and SQL
Polars is a DataFrame interface on top of an OLAP Query Engine implemented in Rust using
[Apache Arrow Columnar Format](https://arrow.apache.org/docs/format/Columnar.html) as the memory
model.
- Lazy | eager execution
- Multi-threaded
- SIMD
- Query optimization
- Powerful expression API
- Hybrid Streaming (larger-than-RAM datasets)
- Rust | Python | NodeJS | R | ...
To learn more, read the [user guide](https://docs.pola.rs/).
## Python
```python
>>> 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"),
... pl.col("A").sum().over("fruits").alias("sum_A_by_fruits"),
... pl.col("A").reverse().over("fruits").alias("rev_A_by_fruits"),
... pl.col("A").sort_by("B").over("fruits").alias("sort_A_by_B_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 │
└──────────┴──────────┴──────────────┴─────┴─────────────┴─────────────┴─────────────┴─────────────┘
```
## SQL
```python
>>> df = pl.scan_csv("docs/assets/data/iris.csv")
>>> ## OPTION 1
>>> # run SQL queries on frame-level
>>> df.sql("""
... SELECT species,
... AVG(sepal_length) AS avg_sepal_length
... FROM self
... GROUP BY species
... """).collect()
shape: (3, 2)
┌────────────┬──────────────────┐
│ species ┆ avg_sepal_length │
│ --- ┆ --- │
│ str ┆ f64 │
╞════════════╪══════════════════╡
│ Virginica ┆ 6.588 │
│ Versicolor ┆ 5.936 │
│ Setosa ┆ 5.006 │
└────────────┴──────────────────┘
>>> ## OPTION 2
>>> # use pl.sql() to operate on the global context
>>> df2 = pl.LazyFrame({
... "species": ["Setosa", "Versicolor", "Virginica"],
... "blooming_season": ["Spring", "Summer", "Fall"]
...})
>>> pl.sql("""
... SELECT df.species,
... AVG(df.sepal_length) AS avg_sepal_length,
... df2.blooming_season
... FROM df
... LEFT JOIN df2 ON df.species = df2.species
... GROUP BY df.species, df2.blooming_season
... """).collect()
```
SQL commands can also be run directly from your terminal using the Polars CLI:
```bash
# run an inline SQL query
> polars -c "SELECT species, AVG(sepal_length) AS avg_sepal_length, AVG(sepal_width) AS avg_sepal_width FROM read_csv('docs/assets/data/iris.csv') GROUP BY species;"
# run interactively
> polars
Polars CLI v0.3.0
Type .help for help.
> SELECT species, AVG(sepal_length) AS avg_sepal_length, AVG(sepal_width) AS avg_sepal_width FROM read_csv('docs/assets/data/iris.csv') GROUP BY species;
```
Refer to the [Polars CLI repository](https://github.com/pola-rs/polars-cli) for more information.
## Performance 🚀🚀
### Blazingly fast
Polars is very fast. In fact, it is one of the best performing solutions available. See the
[PDS-H benchmarks](https://www.pola.rs/benchmarks.html) results.
### Lightweight
Polars is also very lightweight. It comes with zero required dependencies, and this shows in the
import times:
- polars: 70ms
- numpy: 104ms
- pandas: 520ms
### Handles larger-than-RAM data
If you have data that does not fit into memory, Polars' query engine is able to process your query
(or parts of your query) in a streaming fashion. This drastically reduces memory requirements, so
you might be able to process your 250GB dataset on your laptop. Collect with
`collect(engine='streaming')` to run the query streaming. (This might be a little slower, but it is
still very fast!)
## Setup
### Python
Install the latest Polars version with:
```sh
pip install polars
```
We also have a conda package (`conda install -c conda-forge polars`), however pip is the preferred
way to install Polars.
Install Polars with all optional dependencies.
```sh
pip install 'polars[all]'
```
You can also install a subset of all optional dependencies.
```sh
pip install 'polars[numpy,pandas,pyarrow]'
```
See the [User Guide](https://docs.pola.rs/user-guide/installation/#feature-flags) for more details
on optional dependencies
To see the current Polars version and a full list of its optional dependencies, run:
```python
pl.show_versions()
```
Releases happen quite often (weekly / every few days) at the moment, so updating Polars regularly to
get the latest bugfixes / features might not be a bad idea.
### Rust
You can take latest release from `crates.io`, or if you want to use the latest features /
performance improvements point to the `main` branch of this repo.
```toml
polars = { git = "https://github.com/pola-rs/polars", rev = "<optional git tag>" }
```
Requires Rust version `>=1.80`.
## Contributing
Want to contribute? Read our [contributing guide](https://docs.pola.rs/development/contributing/).
## Python: compile Polars from source
If you want a bleeding edge release or maximal performance you should compile Polars from source.
This can be done by going through the following steps in sequence:
1. Install the latest [Rust compiler](https://www.rust-lang.org/tools/install)
2. Install [maturin](https://maturin.rs/): `pip install maturin`
3. `cd py-polars` and choose one of the following:
- `make build`, slow binary with debug assertions and symbols, fast compile times
- `make build-release`, fast binary without debug assertions, minimal debug symbols, long compile
times
- `make build-nodebug-release`, same as build-release but without any debug symbols, slightly
faster to compile
- `make build-debug-release`, same as build-release but with full debug symbols, slightly slower
to compile
- `make build-dist-release`, fastest binary, extreme compile times
By default the binary is compiled with optimizations turned on for a modern CPU. Specify `LTS_CPU=1`
with the command if your CPU is older and does not support e.g. AVX2.
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`.
## Using custom Rust functions in Python
Extending Polars with UDFs compiled in Rust is easy. We expose PyO3 extensions for `DataFrame` and
`Series` data structures. See more in https://github.com/pola-rs/polars/tree/main/pyo3-polars.
## Going big...
Do you expect more than 2^32 (~4.2 billion) rows? Compile Polars with the `bigidx` feature flag or,
for Python users, install `pip install polars-u64-idx`.
Don't use this unless you hit the row boundary as the default build of Polars is faster and consumes
less memory.
## Legacy
Do you want Polars to run on an old CPU (e.g. dating from before 2011), or on an `x86-64` build of
Python on Apple Silicon under Rosetta? Install `pip install polars-lts-cpu`. This version of Polars
is compiled without [AVX](https://en.wikipedia.org/wiki/Advanced_Vector_Extensions) target features.
## Sponsors
[<img src="https://www.jetbrains.com/company/brand/img/jetbrains_logo.png" height="50" alt="JetBrains logo" />](https://www.jetbrains.com)
Raw data
{
"_id": null,
"home_page": null,
"name": "polars-u64-idx",
"maintainer": null,
"docs_url": null,
"requires_python": ">=3.9",
"maintainer_email": null,
"keywords": "dataframe, arrow, out-of-core",
"author": null,
"author_email": "Ritchie Vink <ritchie46@gmail.com>",
"download_url": "https://files.pythonhosted.org/packages/fb/0b/4b8238b3040493d7b4cdcd16a6354d5b74ba89300a24067b3c5df3a2ae3e/polars_u64_idx-1.33.0.tar.gz",
"platform": null,
"description": "<h1 align=\"center\">\n <a href=\"https://pola.rs\">\n <img src=\"https://raw.githubusercontent.com/pola-rs/polars-static/master/banner/polars_github_banner.svg\" alt=\"Polars logo\">\n </a>\n</h1>\n\n<div align=\"center\">\n <a href=\"https://crates.io/crates/polars\">\n <img src=\"https://img.shields.io/crates/v/polars.svg\" alt=\"crates.io Latest Release\"/>\n </a>\n <a href=\"https://pypi.org/project/polars/\">\n <img src=\"https://img.shields.io/pypi/v/polars.svg\" alt=\"PyPi Latest Release\"/>\n </a>\n <a href=\"https://www.npmjs.com/package/nodejs-polars\">\n <img src=\"https://img.shields.io/npm/v/nodejs-polars.svg\" alt=\"NPM Latest Release\"/>\n </a>\n <a href=\"https://community.r-multiverse.org/polars\">\n <img src=\"https://img.shields.io/badge/dynamic/json?url=https%3A%2F%2Fcommunity.r-multiverse.org%2Fapi%2Fpackages%2Fpolars&query=%24.Version&label=r-multiverse\" alt=\"R-multiverse Latest Release\"/>\n </a>\n <a href=\"https://doi.org/10.5281/zenodo.7697217\">\n <img src=\"https://zenodo.org/badge/DOI/10.5281/zenodo.7697217.svg\" alt=\"DOI Latest Release\"/>\n </a>\n</div>\n\n<p align=\"center\">\n <b>Documentation</b>:\n <a href=\"https://docs.pola.rs/api/python/stable/reference/index.html\">Python</a>\n -\n <a href=\"https://docs.rs/polars/latest/polars/\">Rust</a>\n -\n <a href=\"https://pola-rs.github.io/nodejs-polars/index.html\">Node.js</a>\n -\n <a href=\"https://pola-rs.github.io/r-polars/index.html\">R</a>\n |\n <b>StackOverflow</b>:\n <a href=\"https://stackoverflow.com/questions/tagged/python-polars\">Python</a>\n -\n <a href=\"https://stackoverflow.com/questions/tagged/rust-polars\">Rust</a>\n -\n <a href=\"https://stackoverflow.com/questions/tagged/nodejs-polars\">Node.js</a>\n -\n <a href=\"https://stackoverflow.com/questions/tagged/r-polars\">R</a>\n |\n <a href=\"https://docs.pola.rs/\">User guide</a>\n |\n <a href=\"https://discord.gg/4UfP5cfBE7\">Discord</a>\n</p>\n\n## Polars: Blazingly fast DataFrames in Rust, Python, Node.js, R, and SQL\n\nPolars is a DataFrame interface on top of an OLAP Query Engine implemented in Rust using\n[Apache Arrow Columnar Format](https://arrow.apache.org/docs/format/Columnar.html) as the memory\nmodel.\n\n- Lazy | eager execution\n- Multi-threaded\n- SIMD\n- Query optimization\n- Powerful expression API\n- Hybrid Streaming (larger-than-RAM datasets)\n- Rust | Python | NodeJS | R | ...\n\nTo learn more, read the [user guide](https://docs.pola.rs/).\n\n## Python\n\n```python\n>>> import polars as pl\n>>> df = pl.DataFrame(\n... {\n... \"A\": [1, 2, 3, 4, 5],\n... \"fruits\": [\"banana\", \"banana\", \"apple\", \"apple\", \"banana\"],\n... \"B\": [5, 4, 3, 2, 1],\n... \"cars\": [\"beetle\", \"audi\", \"beetle\", \"beetle\", \"beetle\"],\n... }\n... )\n\n# embarrassingly parallel execution & very expressive query language\n>>> df.sort(\"fruits\").select(\n... \"fruits\",\n... \"cars\",\n... pl.lit(\"fruits\").alias(\"literal_string_fruits\"),\n... pl.col(\"B\").filter(pl.col(\"cars\") == \"beetle\").sum(),\n... pl.col(\"A\").filter(pl.col(\"B\") > 2).sum().over(\"cars\").alias(\"sum_A_by_cars\"),\n... pl.col(\"A\").sum().over(\"fruits\").alias(\"sum_A_by_fruits\"),\n... pl.col(\"A\").reverse().over(\"fruits\").alias(\"rev_A_by_fruits\"),\n... pl.col(\"A\").sort_by(\"B\").over(\"fruits\").alias(\"sort_A_by_B_by_fruits\"),\n... )\nshape: (5, 8)\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n\u2502 fruits \u2506 cars \u2506 literal_stri \u2506 B \u2506 sum_A_by_ca \u2506 sum_A_by_fr \u2506 rev_A_by_fr \u2506 sort_A_by_B \u2502\n\u2502 --- \u2506 --- \u2506 ng_fruits \u2506 --- \u2506 rs \u2506 uits \u2506 uits \u2506 _by_fruits \u2502\n\u2502 str \u2506 str \u2506 --- \u2506 i64 \u2506 --- \u2506 --- \u2506 --- \u2506 --- \u2502\n\u2502 \u2506 \u2506 str \u2506 \u2506 i64 \u2506 i64 \u2506 i64 \u2506 i64 \u2502\n\u255e\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2561\n\u2502 \"apple\" \u2506 \"beetle\" \u2506 \"fruits\" \u2506 11 \u2506 4 \u2506 7 \u2506 4 \u2506 4 \u2502\n\u2502 \"apple\" \u2506 \"beetle\" \u2506 \"fruits\" \u2506 11 \u2506 4 \u2506 7 \u2506 3 \u2506 3 \u2502\n\u2502 \"banana\" \u2506 \"beetle\" \u2506 \"fruits\" \u2506 11 \u2506 4 \u2506 8 \u2506 5 \u2506 5 \u2502\n\u2502 \"banana\" \u2506 \"audi\" \u2506 \"fruits\" \u2506 11 \u2506 2 \u2506 8 \u2506 2 \u2506 2 \u2502\n\u2502 \"banana\" \u2506 \"beetle\" \u2506 \"fruits\" \u2506 11 \u2506 4 \u2506 8 \u2506 1 \u2506 1 \u2502\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n```\n\n## SQL\n\n```python\n>>> df = pl.scan_csv(\"docs/assets/data/iris.csv\")\n>>> ## OPTION 1\n>>> # run SQL queries on frame-level\n>>> df.sql(\"\"\"\n...\tSELECT species,\n...\t AVG(sepal_length) AS avg_sepal_length\n...\tFROM self\n...\tGROUP BY species\n...\t\"\"\").collect()\nshape: (3, 2)\n\u250c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u252c\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2510\n\u2502 species \u2506 avg_sepal_length \u2502\n\u2502 --- \u2506 --- \u2502\n\u2502 str \u2506 f64 \u2502\n\u255e\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u256a\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2550\u2561\n\u2502 Virginica \u2506 6.588 \u2502\n\u2502 Versicolor \u2506 5.936 \u2502\n\u2502 Setosa \u2506 5.006 \u2502\n\u2514\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2534\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2500\u2518\n>>> ## OPTION 2\n>>> # use pl.sql() to operate on the global context\n>>> df2 = pl.LazyFrame({\n... \"species\": [\"Setosa\", \"Versicolor\", \"Virginica\"],\n... \"blooming_season\": [\"Spring\", \"Summer\", \"Fall\"]\n...})\n>>> pl.sql(\"\"\"\n... SELECT df.species,\n... AVG(df.sepal_length) AS avg_sepal_length,\n... df2.blooming_season\n... FROM df\n... LEFT JOIN df2 ON df.species = df2.species\n... GROUP BY df.species, df2.blooming_season\n... \"\"\").collect()\n```\n\nSQL commands can also be run directly from your terminal using the Polars CLI:\n\n```bash\n# run an inline SQL query\n> polars -c \"SELECT species, AVG(sepal_length) AS avg_sepal_length, AVG(sepal_width) AS avg_sepal_width FROM read_csv('docs/assets/data/iris.csv') GROUP BY species;\"\n\n# run interactively\n> polars\nPolars CLI v0.3.0\nType .help for help.\n\n> SELECT species, AVG(sepal_length) AS avg_sepal_length, AVG(sepal_width) AS avg_sepal_width FROM read_csv('docs/assets/data/iris.csv') GROUP BY species;\n```\n\nRefer to the [Polars CLI repository](https://github.com/pola-rs/polars-cli) for more information.\n\n## Performance \ud83d\ude80\ud83d\ude80\n\n### Blazingly fast\n\nPolars is very fast. In fact, it is one of the best performing solutions available. See the\n[PDS-H benchmarks](https://www.pola.rs/benchmarks.html) results.\n\n### Lightweight\n\nPolars is also very lightweight. It comes with zero required dependencies, and this shows in the\nimport times:\n\n- polars: 70ms\n- numpy: 104ms\n- pandas: 520ms\n\n### Handles larger-than-RAM data\n\nIf you have data that does not fit into memory, Polars' query engine is able to process your query\n(or parts of your query) in a streaming fashion. This drastically reduces memory requirements, so\nyou might be able to process your 250GB dataset on your laptop. Collect with\n`collect(engine='streaming')` to run the query streaming. (This might be a little slower, but it is\nstill very fast!)\n\n## Setup\n\n### Python\n\nInstall the latest Polars version with:\n\n```sh\npip install polars\n```\n\nWe also have a conda package (`conda install -c conda-forge polars`), however pip is the preferred\nway to install Polars.\n\nInstall Polars with all optional dependencies.\n\n```sh\npip install 'polars[all]'\n```\n\nYou can also install a subset of all optional dependencies.\n\n```sh\npip install 'polars[numpy,pandas,pyarrow]'\n```\n\nSee the [User Guide](https://docs.pola.rs/user-guide/installation/#feature-flags) for more details\non optional dependencies\n\nTo see the current Polars version and a full list of its optional dependencies, run:\n\n```python\npl.show_versions()\n```\n\nReleases happen quite often (weekly / every few days) at the moment, so updating Polars regularly to\nget the latest bugfixes / features might not be a bad idea.\n\n### Rust\n\nYou can take latest release from `crates.io`, or if you want to use the latest features /\nperformance improvements point to the `main` branch of this repo.\n\n```toml\npolars = { git = \"https://github.com/pola-rs/polars\", rev = \"<optional git tag>\" }\n```\n\nRequires Rust version `>=1.80`.\n\n## Contributing\n\nWant to contribute? Read our [contributing guide](https://docs.pola.rs/development/contributing/).\n\n## Python: compile Polars from source\n\nIf you want a bleeding edge release or maximal performance you should compile Polars from source.\n\nThis can be done by going through the following steps in sequence:\n\n1. Install the latest [Rust compiler](https://www.rust-lang.org/tools/install)\n2. Install [maturin](https://maturin.rs/): `pip install maturin`\n3. `cd py-polars` and choose one of the following:\n - `make build`, slow binary with debug assertions and symbols, fast compile times\n - `make build-release`, fast binary without debug assertions, minimal debug symbols, long compile\n times\n - `make build-nodebug-release`, same as build-release but without any debug symbols, slightly\n faster to compile\n - `make build-debug-release`, same as build-release but with full debug symbols, slightly slower\n to compile\n - `make build-dist-release`, fastest binary, extreme compile times\n\nBy default the binary is compiled with optimizations turned on for a modern CPU. Specify `LTS_CPU=1`\nwith the command if your CPU is older and does not support e.g. AVX2.\n\nNote that the Rust crate implementing the Python bindings is called `py-polars` to distinguish from\nthe wrapped Rust crate `polars` itself. However, both the Python package and the Python module are\nnamed `polars`, so you can `pip install polars` and `import polars`.\n\n## Using custom Rust functions in Python\n\nExtending Polars with UDFs compiled in Rust is easy. We expose PyO3 extensions for `DataFrame` and\n`Series` data structures. See more in https://github.com/pola-rs/polars/tree/main/pyo3-polars.\n\n## Going big...\n\nDo you expect more than 2^32 (~4.2 billion) rows? Compile Polars with the `bigidx` feature flag or,\nfor Python users, install `pip install polars-u64-idx`.\n\nDon't use this unless you hit the row boundary as the default build of Polars is faster and consumes\nless memory.\n\n## Legacy\n\nDo you want Polars to run on an old CPU (e.g. dating from before 2011), or on an `x86-64` build of\nPython on Apple Silicon under Rosetta? Install `pip install polars-lts-cpu`. This version of Polars\nis compiled without [AVX](https://en.wikipedia.org/wiki/Advanced_Vector_Extensions) target features.\n\n## Sponsors\n\n[<img src=\"https://www.jetbrains.com/company/brand/img/jetbrains_logo.png\" height=\"50\" alt=\"JetBrains logo\" />](https://www.jetbrains.com)\n\n",
"bugtrack_url": null,
"license": null,
"summary": "Blazingly fast DataFrame library",
"version": "1.33.0",
"project_urls": {
"Changelog": "https://github.com/pola-rs/polars/releases",
"Documentation": "https://docs.pola.rs/api/python/stable/reference/index.html",
"Homepage": "https://www.pola.rs/",
"Repository": "https://github.com/pola-rs/polars"
},
"split_keywords": [
"dataframe",
" arrow",
" out-of-core"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "63e3f8fd4e0191848932494b5600de27ef181559f6e67116cd5509b7c7e64a8a",
"md5": "90377e0246d485750cfe5580d02cdd13",
"sha256": "41240753f0805543c4dc3d80429c0078a05dfac51031e2789b3f67be5f6cb9dd"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-macosx_10_12_x86_64.whl",
"has_sig": false,
"md5_digest": "90377e0246d485750cfe5580d02cdd13",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 38651968,
"upload_time": "2025-09-01T16:32:29",
"upload_time_iso_8601": "2025-09-01T16:32:29.046339Z",
"url": "https://files.pythonhosted.org/packages/63/e3/f8fd4e0191848932494b5600de27ef181559f6e67116cd5509b7c7e64a8a/polars_u64_idx-1.33.0-cp39-abi3-macosx_10_12_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "5b3f1b22bdb61ed011a4e7c36e5e17f7e2103c3bb28f8772200b842929c26cb0",
"md5": "423483f7f441fdf73e565c257cf092f6",
"sha256": "1c74dc5338393d860633c1b8b8b80bf0df8082786ca9701c2a5aa3d9a6766338"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-macosx_11_0_arm64.whl",
"has_sig": false,
"md5_digest": "423483f7f441fdf73e565c257cf092f6",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 35112455,
"upload_time": "2025-09-01T16:32:32",
"upload_time_iso_8601": "2025-09-01T16:32:32.645588Z",
"url": "https://files.pythonhosted.org/packages/5b/3f/1b22bdb61ed011a4e7c36e5e17f7e2103c3bb28f8772200b842929c26cb0/polars_u64_idx-1.33.0-cp39-abi3-macosx_11_0_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "3d1a6296d1e50cf9cf6d0d09956fe92d6f52b00d12dc0f88daf7c40767082804",
"md5": "b3565936cce9e304b747f2bb3ae918ed",
"sha256": "fb22db92194264b196e20fa8905f96cc0037962faf54afe1e05ab6fb33ad9a56"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"has_sig": false,
"md5_digest": "b3565936cce9e304b747f2bb3ae918ed",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 39249390,
"upload_time": "2025-09-01T16:32:35",
"upload_time_iso_8601": "2025-09-01T16:32:35.653782Z",
"url": "https://files.pythonhosted.org/packages/3d/1a/6296d1e50cf9cf6d0d09956fe92d6f52b00d12dc0f88daf7c40767082804/polars_u64_idx-1.33.0-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "6a0c0c650465e100e3184f648d127f302555a86b44cdf1557648f9f83b9fa4cf",
"md5": "47289555f40c29b3f8a657b0e675ac54",
"sha256": "4263125a1bb05b8d455783aac8bbc8a6798cf00fae169b648c263ee750e71e14"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-manylinux_2_24_aarch64.whl",
"has_sig": false,
"md5_digest": "47289555f40c29b3f8a657b0e675ac54",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 36153805,
"upload_time": "2025-09-01T16:32:38",
"upload_time_iso_8601": "2025-09-01T16:32:38.323466Z",
"url": "https://files.pythonhosted.org/packages/6a/0c/0c650465e100e3184f648d127f302555a86b44cdf1557648f9f83b9fa4cf/polars_u64_idx-1.33.0-cp39-abi3-manylinux_2_24_aarch64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "a27b9f8f275228f03fa3039df9928fbe52b50280385dce0f234f8a78bc971d67",
"md5": "09a24d52f26d271c59cfc5be21d9da02",
"sha256": "c73ec742b6ab11cf6d2e63970549c17c18f1abadbb55670846bb7e26e5ef9746"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-win_amd64.whl",
"has_sig": false,
"md5_digest": "09a24d52f26d271c59cfc5be21d9da02",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 38822321,
"upload_time": "2025-09-01T16:32:41",
"upload_time_iso_8601": "2025-09-01T16:32:41.138989Z",
"url": "https://files.pythonhosted.org/packages/a2/7b/9f8f275228f03fa3039df9928fbe52b50280385dce0f234f8a78bc971d67/polars_u64_idx-1.33.0-cp39-abi3-win_amd64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "82d943d6075a0dda62c546f5db4b9f5486231defe297e4e7639d061d0e15c0af",
"md5": "18ca77b36c86617c19f4848d9d1483b1",
"sha256": "0b21ded50405df4e38faa12464043c4d8d867b4b25b583ec670646111ebfa7e2"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0-cp39-abi3-win_arm64.whl",
"has_sig": false,
"md5_digest": "18ca77b36c86617c19f4848d9d1483b1",
"packagetype": "bdist_wheel",
"python_version": "cp39",
"requires_python": ">=3.9",
"size": 34947032,
"upload_time": "2025-09-01T16:32:43",
"upload_time_iso_8601": "2025-09-01T16:32:43.853333Z",
"url": "https://files.pythonhosted.org/packages/82/d9/43d6075a0dda62c546f5db4b9f5486231defe297e4e7639d061d0e15c0af/polars_u64_idx-1.33.0-cp39-abi3-win_arm64.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "fb0b4b8238b3040493d7b4cdcd16a6354d5b74ba89300a24067b3c5df3a2ae3e",
"md5": "efb45f3b0a9ad8c3bc9afbdcf3491308",
"sha256": "8e0eea94bcf7ed4a6c16d64c0863f072cfb2a707f282c0568cb17d69a98b867f"
},
"downloads": -1,
"filename": "polars_u64_idx-1.33.0.tar.gz",
"has_sig": false,
"md5_digest": "efb45f3b0a9ad8c3bc9afbdcf3491308",
"packagetype": "sdist",
"python_version": "source",
"requires_python": ">=3.9",
"size": 4811217,
"upload_time": "2025-09-01T16:32:50",
"upload_time_iso_8601": "2025-09-01T16:32:50.178352Z",
"url": "https://files.pythonhosted.org/packages/fb/0b/4b8238b3040493d7b4cdcd16a6354d5b74ba89300a24067b3c5df3a2ae3e/polars_u64_idx-1.33.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-09-01 16:32:50",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "pola-rs",
"github_project": "polars",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "polars-u64-idx"
}