Skip to main content

Common place for GFW reusable Python components.

Project description

gfw-common

Python versions Last release

Common place for GFW reusable Python components.

Introduction

The following table shows a summary of the current supported features:

Module/Package Description
gfw.common.beam Common utilities and wrappers for Apache Beam pipelines.
gfw.common.cli Lightweight framework around argparse for building CLIs more easily.
gfw.common.bigquery Common utilities and wrappers for BigQuery interactions.
gfw.common.datetime Simple helper functions around stdlib datetime module.
gfw.common.decorators.py Basic function decorators.
gfw.common.dictionaries.py Simple helper functions for dictionary manipulation.
gfw.common.io.py Basic IO functions.
gfw.common.iterables.py Iterables utilities.
gfw.common.logging.py Basic logging configuration.
gfw.common.serialization.py Basic serialization utilities.

For more information and API reference, check the documentation pages.

Installation

The package offers extras to avoid installing unnecessary dependencies:

  • beam: includes dependencies for the gfw.common.beam package.
  • bq: includes dependencies for BigQuery utilities.

For a default installation without extras, run:

pip install gfw-common

To install all extras, run:

pip install gfw-common[bq,beam]

Usage

You can see examples in the examples folder.

How to Contribute

Preparing the environment

First, clone the repository.

git clone https://github.com/GlobalFishingWatch/gfw-common.git

Install uv for faster installs:

./install-uv.sh

Create virtual environment and activate it:

uv venv
source .venv/bin/activate

Install pre-commit hooks for local development:

make install-pre-commit

Install dependencies and package in editable mode for local development:

make install

Make sure you can run unit tests:

make test

Development Workflow

Regarding the git workflow, we follow GitHub Flow. See GITHUB-FLOW.md for a quick summary.

Try to write good commit messages. See How to Write a Git Commit Message guide for details.

The pre-commit hooks will take care of validating your code before a commit in terms of PEP8 standards, type-checking, miss-pellings, missing documentation, etc. If you want/need to do it manually, you have commands in the Makefile. To see options, type make.

How to Release

Creating a tag will automatically trigger a GitHub Action (release.yaml) to publish the package to PyPI. The tag must match the version declared in pyproject.toml; this will be validated by the action. The tag name must follow the format vX.Y.Z.

[!NOTE] In this context, X, Y and Z refer to MAJOR, MINOR and PATCH of Semantic Versioning.

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

gfw_common-0.4.1.tar.gz (76.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

gfw_common-0.4.1-py3-none-any.whl (68.8 kB view details)

Uploaded Python 3

File details

Details for the file gfw_common-0.4.1.tar.gz.

File metadata

  • Download URL: gfw_common-0.4.1.tar.gz
  • Upload date:
  • Size: 76.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for gfw_common-0.4.1.tar.gz
Algorithm Hash digest
SHA256 7da0bc0855c4b28777b8cc5b82a3453df07992ed0cb8d8198d5fcf858e1c4cd6
MD5 aad0c1dcea4c17ee523ed131cbb1bb78
BLAKE2b-256 70a880a3df8fc60122dc1a9890f0cab81374d06ceb6b6c2971ca60bb266baf9d

See more details on using hashes here.

File details

Details for the file gfw_common-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: gfw_common-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 68.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for gfw_common-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 9214f8b24c552dbfcf0d8257e204c263625a3be2c72bde0f2edb5e89c77a0106
MD5 d1bc93db19c12ef49aa34afdd077c52c
BLAKE2b-256 656daa17ae59a2e147b15b5c4b57a4c2851713f0e1c1042e366cc7b45d3dd4f3

See more details on using hashes here.

Supported by

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