Skip to main content

Simple tool set for filtering DataFrames by building queries from one or more filters.

Project description

Transude

Simple tool set for filtering DataFrames (Pandas or Polars*) by building queries from one or more filters. This is useful for connecting filtering controls on DataFrames using touch screen controls.

This project was developed with some consulting from ChatGPT. There were a few concepts I didn't understand until I had someone I could point more specific questions towards and see working examples. Most of the scaffolding was written before consulting as it really tends to speed up responses and keep the conversation on track. This is also a refactor of old code I use in a current project.

Installation:

pip install transude

Usage:

import pandas as pd
import transude as txd

# Create a DataFrame using Pandas
pd_df = pd.DataFrame(...)

# Get a filtered version of the DataFrame using Transude
filtered_pd_df = txd.filter_df(data_frame=pd_df, columns='col1', values=['val1', 'val2'], operator='==', joiner='or')

If you need to manage the DataFrameFilters directly, you can use a DataFrameFilterManager like so:

pd_df_filter_manager = DataFrameFilterManager()

# Example of adding a single DataFrameFilter and clearing the filters.  Filters can be removed one by one as well.
pd_df_filter_manager.add_filter(DataFrameFilter(columns='col1', values='val1', operator='==', joiner='or'))
pd_df_filter_manager.clear_filters()

# The following utilizes the DataFrameFilterFactory to create multiple filters and then adds them all to the builder.
pd_filter_factory = DataFrameFilterFactory(columns='col1', values=['val1', 'val2'], operator='==', joiner='or')
pd_filters = pd_filter_factory.create_filters()
pd_df_filter_manager.add_filters(pd_filters)
query_string = pd_df_filter_manager.build_query()

# In order to apply the filters, call query using the query_string
pd_df.query(query_string)

--*Polars compatability coming soon.

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

transude-1.1.0.tar.gz (6.9 kB view details)

Uploaded Source

Built Distribution

transude-1.1.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file transude-1.1.0.tar.gz.

File metadata

  • Download URL: transude-1.1.0.tar.gz
  • Upload date:
  • Size: 6.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for transude-1.1.0.tar.gz
Algorithm Hash digest
SHA256 bcec2bfe161aa8f80b87d78138b42b5e2c1f4e3c3249adbe23a6d313e5e1f6b5
MD5 128dbdd205bbcc841c024096c087af47
BLAKE2b-256 a6a399e55d722cdec56ceb1a9052ddcf44e0c347660054e11e28811e09506918

See more details on using hashes here.

File details

Details for the file transude-1.1.0-py3-none-any.whl.

File metadata

  • Download URL: transude-1.1.0-py3-none-any.whl
  • Upload date:
  • Size: 7.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.0

File hashes

Hashes for transude-1.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 47c052ce8d71130f74c3d737dda6ab8f8159d5a7e7784e948c0e296e2c763c08
MD5 1ec5cb99fffe2284210a716b0a581404
BLAKE2b-256 b79b0049c0ea2cd8383f59486a2bab3f5fab02d3a8b8b4e5843f80f4afea0f22

See more details on using hashes here.

Supported by

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