deltalake


Namedeltalake JSON
Version 0.23.1 PyPI version JSON
download
home_pagehttps://github.com/delta-io/delta-rs
SummaryNative Delta Lake Python binding based on delta-rs with Pandas integration
upload_time2025-01-02 15:04:08
maintainerNone
docs_urlNone
authorQingping Hou <dave2008713@gmail.com>, Will Jones <willjones127@gmail.com>
requires_python>=3.9
licenseApache-2.0
keywords deltalake delta datalake pandas arrow
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            # Deltalake-python

[![PyPI](https://img.shields.io/pypi/v/deltalake.svg?style=flat-square)](https://pypi.org/project/deltalake/)
[![userdoc](https://img.shields.io/badge/docs-user-blue)](https://delta-io.github.io/delta-rs/)
[![apidoc](https://img.shields.io/badge/docs-api-blue)](https://delta-io.github.io/delta-rs/api/delta_table/)

Native [Delta Lake](https://delta.io/) Python binding based on
[delta-rs](https://github.com/delta-io/delta-rs) with
[Pandas](https://pandas.pydata.org/) integration.

## Example

```python
from deltalake import DeltaTable
dt = DeltaTable("../rust/tests/data/delta-0.2.0")
dt.version()
3
dt.files()
['part-00000-cb6b150b-30b8-4662-ad28-ff32ddab96d2-c000.snappy.parquet',
 'part-00000-7c2deba3-1994-4fb8-bc07-d46c948aa415-c000.snappy.parquet',
 'part-00001-c373a5bd-85f0-4758-815e-7eb62007a15c-c000.snappy.parquet']
```

See the [user guide](https://delta-io.github.io/delta-rs/usage/installation/) for more examples.

## Installation

```bash
# with pip
pip install deltalake
# with uv
uv add deltalake
# with poetry
poetry add deltalake
```

NOTE: official binary wheels are linked against openssl statically for remote
objection store communication. Please file Github issue to request for critical
openssl upgrade.

## Build custom wheels

Sometimes you may wish to build custom wheels. Maybe you want to try out some
unreleased features. Or maybe you want to tweak the optimization of the Rust code.

To compile the package, you will need the Rust compiler and [maturin](https://github.com/PyO3/maturin):

```sh
curl https://sh.rustup.rs -sSf | sh -s

Then you can build wheels for your own platform like so:

```sh
uvx maturin build --release --out wheels
```

Note:

- [`uvx`](https://docs.astral.sh/uv/guides/tools/) invokes a tool without installing it.
- if you plan to often use `maturin`, you can install the "tool" with `uv tool install maturin`.

For a build that is optimized for the system you are on (but sacrificing portability):

```sh
RUSTFLAGS="-C target-cpu=native" uvx maturin build --release --out wheels
```

### Cross compilation

The above command only works for your current platform. To create wheels for other
platforms, you'll need to cross compile. Cross compilation requires installing
two additional components: to cross compile Rust code, you will need to install
the target with `rustup`; to cross compile the Python bindings, you will need
to install `ziglang`.

The following example is for manylinux2014. Other targets will require different
Rust `target` and Python `compatibility` tags.

```sh
rustup target add x86_64-unknown-linux-gnu
```

Then you can build wheels for the target platform like so:

```sh
uvx --from 'maturin[zig]' maturin build --release --zig \
    --target x86_64-unknown-linux-gnu \
    --compatibility manylinux2014 \
    --out wheels
```

If you expect to only run on more modern system, you can set a newer `target-cpu`
flag to Rust and use a newer compatibility tag for Linux. For example, here
we set compatibility with CPUs newer than Haswell (2013) and Linux OS with
glibc version of at least 2.24:

```sh
RUSTFLAGS="-C target-cpu=haswell" uvx --from 'maturin[zig]' maturin build --release --zig \
    --target x86_64-unknown-linux-gnu \
    --compatibility manylinux_2_24 \
    --out wheels
```

See note about `RUSTFLAGS` from [the arrow-rs readme](https://github.com/apache/arrow-rs/blob/master/arrow/README.md#performance-tips).


            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/delta-io/delta-rs",
    "name": "deltalake",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": null,
    "keywords": "deltalake, delta, datalake, pandas, arrow",
    "author": "Qingping Hou <dave2008713@gmail.com>, Will Jones <willjones127@gmail.com>",
    "author_email": "Qingping Hou <dave2008713@gmail.com>, Will Jones <willjones127@gmail.com>",
    "download_url": "https://files.pythonhosted.org/packages/1c/22/f6876f88ba3bb5fd9aab1819272421d2c4a0cd036355df29a4d02ed74dd1/deltalake-0.23.1.tar.gz",
    "platform": null,
    "description": "# Deltalake-python\n\n[![PyPI](https://img.shields.io/pypi/v/deltalake.svg?style=flat-square)](https://pypi.org/project/deltalake/)\n[![userdoc](https://img.shields.io/badge/docs-user-blue)](https://delta-io.github.io/delta-rs/)\n[![apidoc](https://img.shields.io/badge/docs-api-blue)](https://delta-io.github.io/delta-rs/api/delta_table/)\n\nNative [Delta Lake](https://delta.io/) Python binding based on\n[delta-rs](https://github.com/delta-io/delta-rs) with\n[Pandas](https://pandas.pydata.org/) integration.\n\n## Example\n\n```python\nfrom deltalake import DeltaTable\ndt = DeltaTable(\"../rust/tests/data/delta-0.2.0\")\ndt.version()\n3\ndt.files()\n['part-00000-cb6b150b-30b8-4662-ad28-ff32ddab96d2-c000.snappy.parquet',\n 'part-00000-7c2deba3-1994-4fb8-bc07-d46c948aa415-c000.snappy.parquet',\n 'part-00001-c373a5bd-85f0-4758-815e-7eb62007a15c-c000.snappy.parquet']\n```\n\nSee the [user guide](https://delta-io.github.io/delta-rs/usage/installation/) for more examples.\n\n## Installation\n\n```bash\n# with pip\npip install deltalake\n# with uv\nuv add deltalake\n# with poetry\npoetry add deltalake\n```\n\nNOTE: official binary wheels are linked against openssl statically for remote\nobjection store communication. Please file Github issue to request for critical\nopenssl upgrade.\n\n## Build custom wheels\n\nSometimes you may wish to build custom wheels. Maybe you want to try out some\nunreleased features. Or maybe you want to tweak the optimization of the Rust code.\n\nTo compile the package, you will need the Rust compiler and [maturin](https://github.com/PyO3/maturin):\n\n```sh\ncurl https://sh.rustup.rs -sSf | sh -s\n\nThen you can build wheels for your own platform like so:\n\n```sh\nuvx maturin build --release --out wheels\n```\n\nNote:\n\n- [`uvx`](https://docs.astral.sh/uv/guides/tools/) invokes a tool without installing it.\n- if you plan to often use `maturin`, you can install the \"tool\" with `uv tool install maturin`.\n\nFor a build that is optimized for the system you are on (but sacrificing portability):\n\n```sh\nRUSTFLAGS=\"-C target-cpu=native\" uvx maturin build --release --out wheels\n```\n\n### Cross compilation\n\nThe above command only works for your current platform. To create wheels for other\nplatforms, you'll need to cross compile. Cross compilation requires installing\ntwo additional components: to cross compile Rust code, you will need to install\nthe target with `rustup`; to cross compile the Python bindings, you will need\nto install `ziglang`.\n\nThe following example is for manylinux2014. Other targets will require different\nRust `target` and Python `compatibility` tags.\n\n```sh\nrustup target add x86_64-unknown-linux-gnu\n```\n\nThen you can build wheels for the target platform like so:\n\n```sh\nuvx --from 'maturin[zig]' maturin build --release --zig \\\n    --target x86_64-unknown-linux-gnu \\\n    --compatibility manylinux2014 \\\n    --out wheels\n```\n\nIf you expect to only run on more modern system, you can set a newer `target-cpu`\nflag to Rust and use a newer compatibility tag for Linux. For example, here\nwe set compatibility with CPUs newer than Haswell (2013) and Linux OS with\nglibc version of at least 2.24:\n\n```sh\nRUSTFLAGS=\"-C target-cpu=haswell\" uvx --from 'maturin[zig]' maturin build --release --zig \\\n    --target x86_64-unknown-linux-gnu \\\n    --compatibility manylinux_2_24 \\\n    --out wheels\n```\n\nSee note about `RUSTFLAGS` from [the arrow-rs readme](https://github.com/apache/arrow-rs/blob/master/arrow/README.md#performance-tips).\n\n",
    "bugtrack_url": null,
    "license": "Apache-2.0",
    "summary": "Native Delta Lake Python binding based on delta-rs with Pandas integration",
    "version": "0.23.1",
    "project_urls": {
        "Homepage": "https://github.com/delta-io/delta-rs",
        "documentation": "https://delta-io.github.io/delta-rs/",
        "repository": "https://github.com/delta-io/delta-rs/tree/main/python/"
    },
    "split_keywords": [
        "deltalake",
        " delta",
        " datalake",
        " pandas",
        " arrow"
    ],
    "urls": [
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "e5d5de4d8ce8cafa153f9adb774085bd0f63425f556dda52d1f1adc49af93252",
                "md5": "7a103d4b798bfae37d2b9a63ae629bc3",
                "sha256": "0421237b6981110b254e8df12549f385e52ebadd8f639ac6c053ab350d608b50"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1-cp39-abi3-macosx_10_12_x86_64.whl",
            "has_sig": false,
            "md5_digest": "7a103d4b798bfae37d2b9a63ae629bc3",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.9",
            "size": 39041485,
            "upload_time": "2025-01-02T15:01:02",
            "upload_time_iso_8601": "2025-01-02T15:01:02.252164Z",
            "url": "https://files.pythonhosted.org/packages/e5/d5/de4d8ce8cafa153f9adb774085bd0f63425f556dda52d1f1adc49af93252/deltalake-0.23.1-cp39-abi3-macosx_10_12_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "35d78a9383bb013b9f795e904914c11b10287e2f563abcf2c2d4e3ac653b51c9",
                "md5": "ea4b4745ad75e71d550d4294b395eb60",
                "sha256": "81c37470c18f4e54afec1fb40178d0ea5087139abaa6cdd211dc149c6c2592f7"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1-cp39-abi3-macosx_11_0_arm64.whl",
            "has_sig": false,
            "md5_digest": "ea4b4745ad75e71d550d4294b395eb60",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.9",
            "size": 36649572,
            "upload_time": "2025-01-02T15:00:16",
            "upload_time_iso_8601": "2025-01-02T15:00:16.350952Z",
            "url": "https://files.pythonhosted.org/packages/35/d7/8a9383bb013b9f795e904914c11b10287e2f563abcf2c2d4e3ac653b51c9/deltalake-0.23.1-cp39-abi3-macosx_11_0_arm64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "eac0290fc817118dfc2d84709247ee10a0b6f0520d1ed85d5a0a90f9d0898df7",
                "md5": "c1c3e8b85656687a66a44668b7de17c4",
                "sha256": "65417a3fcbf59d9b7d8af78eee89f40e42ddf34d9ec3dec5363abb780840e0d2"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl",
            "has_sig": false,
            "md5_digest": "c1c3e8b85656687a66a44668b7de17c4",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.9",
            "size": 43085136,
            "upload_time": "2025-01-02T15:20:13",
            "upload_time_iso_8601": "2025-01-02T15:20:13.179856Z",
            "url": "https://files.pythonhosted.org/packages/ea/c0/290fc817118dfc2d84709247ee10a0b6f0520d1ed85d5a0a90f9d0898df7/deltalake-0.23.1-cp39-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "539e0108a7e4ab853498831e8ac139351760dfd163181945c3fbae67877f5e37",
                "md5": "84939ff0d115e7e74e459becf1c4c4d5",
                "sha256": "b62e1278df42a006f18f3d29662897a5bb8c9604bf93eb5745bcec675879dc35"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "has_sig": false,
            "md5_digest": "84939ff0d115e7e74e459becf1c4c4d5",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.9",
            "size": 44641347,
            "upload_time": "2025-01-02T15:04:03",
            "upload_time_iso_8601": "2025-01-02T15:04:03.429034Z",
            "url": "https://files.pythonhosted.org/packages/53/9e/0108a7e4ab853498831e8ac139351760dfd163181945c3fbae67877f5e37/deltalake-0.23.1-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "9a32fbf37a76dd7ffdb6f51c8638958c249f71e052abd1b786fede44c8fecc45",
                "md5": "be95f30cff47a7301f243a361a217be9",
                "sha256": "411ecf51cf72644bdb7d4c1e090d916fac4a1d46f791e8801f8ca7db3b09a9bf"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1-cp39-abi3-win_amd64.whl",
            "has_sig": false,
            "md5_digest": "be95f30cff47a7301f243a361a217be9",
            "packagetype": "bdist_wheel",
            "python_version": "cp39",
            "requires_python": ">=3.9",
            "size": 35697665,
            "upload_time": "2025-01-02T15:15:15",
            "upload_time_iso_8601": "2025-01-02T15:15:15.536065Z",
            "url": "https://files.pythonhosted.org/packages/9a/32/fbf37a76dd7ffdb6f51c8638958c249f71e052abd1b786fede44c8fecc45/deltalake-0.23.1-cp39-abi3-win_amd64.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": null,
            "digests": {
                "blake2b_256": "1c22f6876f88ba3bb5fd9aab1819272421d2c4a0cd036355df29a4d02ed74dd1",
                "md5": "b5f04423a581e328115c406c2d25b7aa",
                "sha256": "4026e8b3551965495b731f57b2eeddc2688b9184318f68d3afa178f0e55f6b0a"
            },
            "downloads": -1,
            "filename": "deltalake-0.23.1.tar.gz",
            "has_sig": false,
            "md5_digest": "b5f04423a581e328115c406c2d25b7aa",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 4907547,
            "upload_time": "2025-01-02T15:04:08",
            "upload_time_iso_8601": "2025-01-02T15:04:08.134356Z",
            "url": "https://files.pythonhosted.org/packages/1c/22/f6876f88ba3bb5fd9aab1819272421d2c4a0cd036355df29a4d02ed74dd1/deltalake-0.23.1.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-02 15:04:08",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "delta-io",
    "github_project": "delta-rs",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": true,
    "lcname": "deltalake"
}
        
Elapsed time: 0.41588s