ParqInspector is a Parquet- and Deltatable viewer for your terminal, built with Textual.
ParqInspector can open local or remote Parquet files and delta-tables and lets you view their contents in a table format.
inspector_2.mp4
ParqInspector can be installed with pip (or pipx).
$ pip install parq-inspector
You start ParqInspector simply by running inspector
from your terminal.
You can also instantly open a local file by using the options --filepath
and --row_limit
, or their short versions -f
and -rl
.
$ inspector --filepath ./data/my_data.parquet --row_limit 500
If row limit is not provided, it will get the default value of 200. Be careful, setting the row limit to a very high value might make the app take a long time to start, or it may not start at all depending on the size of your data.
Currently, ParqInspector supports reading remote files from Azure Data Lake Storage Gen2, Amazon S3 and Google Cloud Storage. In case your storage service does not support anonymous access, you will need to set environment variables in order to make ParqInspector able to authenticate to the service. Currently, ParqInspector supports the following environment variables:
Azure:
AZURE_STORAGE_ACCOUNT_NAME
AZURE_STORAGE_SAS_KEY
AZURE_STORAGE_ACCOUNT_KEY
AZURE_STORAGE_CLIENT_ID
AZURE_STORAGE_CLIENT_SECRET
AZURE_STORAGE_TENANT_ID
AWS:
AWS_ACCESS_KEY_ID
AWS_SECRET_ACCESS_KEY
AWS_REGION
AWS_DEFAULT_REGION
GCP:
GOOGLE_SERVICE_ACCOUNT
GOOGLE_SERVICE_ACCOUNT_KEY
Depending on your method of authentication, not all of the environment variables need to be set.
Remote files can only be opened through the Settings-pane in the UI. Pick the correct cloud provider and in the Path-field, you simply put the URL to your file instead of a local path. ParqInspector uses polars under the hood to read Parquet files and Delta-tales from remote storage, and the supported protocols and url-variants are determined by what polars supports. See more here.
[✓] - reading local single Parquet files
[✓] - reading remote single Parquet files
[] - Reading Parquet datasets
[✓] - Reading Delta tables
If you encounter any issues, bugs or feel there is a feature missing that would be valuable, please create an issue in this repo!