Skip to main content

Sensible multi-core apply function for Pandas

Project description

mapply

build codecov pypi Version python downloads

mapply provides a sensible multi-core apply function for Pandas.

mapply vs. pandarallel vs. swifter

Where pandarallel relies on in-house multiprocessing and progressbars, and hard-codes 1 chunk per worker (which will cause idle CPUs when one chunk happens to be more expensive than the others), swifter relies on the heavy dask framework for multiprocessing (converting to Dask DataFrames and back). In an attempt to find the golden mean, mapply is highly customizable and remains lightweight, using tqdm for progressbars and leveraging the powerful pathos framework, which shadows Python's built-in multiprocessing module using dill for universal pickling. Chunks of work are assigned to worker processes "just in time" from a shared queue, allowing irregular workloads to finish faster.

Installation

This pure-Python, OS independent package is available on PyPI:

$ pip install mapply

Usage

readthedocs

For documentation, see mapply.readthedocs.io.

import pandas as pd
import mapply

mapply.init(
    n_workers=-1,
    chunk_size=100,
    max_chunks_per_worker=8,
    progressbar=False,
)

df = pd.DataFrame({"A": list(range(100))})

# avoid unnecessary multiprocessing:
# due to chunk_size=100, this will act as regular apply.
# set chunk_size=1 to skip this check and let max_chunks_per_worker decide.
df["squared"] = df.A.mapply(lambda x: x**2)

Development

gitmoji pre-commit ruff

Run make help for options like installing for development, linting, testing, and building docs.


BSD 3-Clause License

Copyright (c) 2024, ddelange, ddelange@delange.dev

All rights reserved.

Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:

  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.

  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.

  3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.

THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

SPDX-License-Identifier: BSD-3-Clause

Project details


Download files

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

Source Distribution

mapply-0.1.28.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

mapply-0.1.28-py3-none-any.whl (13.8 kB view details)

Uploaded Python 3

File details

Details for the file mapply-0.1.28.tar.gz.

File metadata

  • Download URL: mapply-0.1.28.tar.gz
  • Upload date:
  • Size: 10.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mapply-0.1.28.tar.gz
Algorithm Hash digest
SHA256 d2569727f5e101019b56d81d1ec24f9b4bdb53c1eec1f637bec33d8e78486b3c
MD5 02eab78380ac8a715944373b15799c9c
BLAKE2b-256 ae1d434d599596553c40fcaebbe4e5ef7a2161d4d9c9e195963939dc2839907b

See more details on using hashes here.

Provenance

The following attestation bundles were made for mapply-0.1.28.tar.gz:

Publisher: CD.yml on ddelange/mapply

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mapply-0.1.28-py3-none-any.whl.

File metadata

  • Download URL: mapply-0.1.28-py3-none-any.whl
  • Upload date:
  • Size: 13.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.8

File hashes

Hashes for mapply-0.1.28-py3-none-any.whl
Algorithm Hash digest
SHA256 eba4ed49b6a9828c45e87ab641f4ec969e369a06c0edc1a7002cbeeb207d081c
MD5 d49e902ca53e07ada1dcbe2169486039
BLAKE2b-256 011ac3efe4be8ec91a02f77c3f49cd51ffbca59d83a8660a374506ec2f7381c9

See more details on using hashes here.

Provenance

The following attestation bundles were made for mapply-0.1.28-py3-none-any.whl:

Publisher: CD.yml on ddelange/mapply

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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