Skip to main content

Parse Grisbi .gsb files into typed domain objects and pandas DataFrames

Project description

gsbparse

A Python library for parsing Grisbi .gsb accounting files into typed domain objects, with an optional pandas adapter for DataFrame output.

Documentation: gsbparse.readthedocs.io

Installation

pip install gsbparse

Or with uv:

uv add gsbparse

Requires Python 3.13+.

Quickstart

Read a file

import gsbparse

gsb = gsbparse.read_gsb("my_accounts.gsb")

Inspect typed sections

>>> gsb.currencies
[CurrencySection(Nb=1, Na='Euro', Co='€', Ico='EUR', Fl=2), CurrencySection(Nb=2, Na='US Dollar', Co='$', Ico='USD', Fl=2)]

>>> for account in gsb.accounts:
...     print(account.Number, account.Name)
1 Checking
2 Savings

Detailed transactions (foreign keys resolved)

>>> tx = gsb.detailed_transactions[0]
>>> tx.Dt
datetime.date(2024, 1, 5)
>>> tx.Am
Decimal('-42.50')
>>> tx.Ac.Name
'Checking'
>>> tx.Pa.Na
'Supermarket'

Convert to pandas DataFrame

>>> import gsbparse.pandas as gsbpd
>>> gsbpd.to_df(gsb.currencies)
   Nb         Na Co  Ico  Fl
0   1       Euro    EUR   2
1   2  US Dollar  $  USD   2

Custom column projection:

>>> from gsbparse import DetailedTransactionColumn
>>> columns = [
...     DetailedTransactionColumn(path="Dt",      output_name="date"),
...     DetailedTransactionColumn(path="Am",      output_name="amount"),
...     DetailedTransactionColumn(path="Ac.Name", output_name="account"),
...     DetailedTransactionColumn(path="Pa.Na",   output_name="party"),
...     DetailedTransactionColumn(path="Ca.Na",   output_name="category"),
... ]
>>> gsbpd.to_df(gsb.detailed_transactions, columns=columns)
         date   amount   account        party category
0  2024-01-05   -42.50  Checking  Supermarket     Food
1  2024-01-31  2500.00  Checking     Employer   Income

See the full quickstart and API reference on Read the Docs.

Development

git clone https://github.com/etnbsd/gsbparse.git
cd gsbparse
uv sync --dev
pre-commit install

Common commands (via make):

Command What it does
make test Run the test suite
make lint Run ruff check
make format Run ruff format
make type-check Run mypy in strict mode
make import-check Enforce hexagonal import boundaries
make ci Run all of the above

Contributing

  1. Fork the repo and create a short-lived branch.
  2. Follow Conventional Commits — enforced by pre-commit.
  3. Open a pull request against main.

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

gsbparse-0.5.2.tar.gz (123.0 kB view details)

Uploaded Source

Built Distribution

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

gsbparse-0.5.2-py3-none-any.whl (62.8 kB view details)

Uploaded Python 3

File details

Details for the file gsbparse-0.5.2.tar.gz.

File metadata

  • Download URL: gsbparse-0.5.2.tar.gz
  • Upload date:
  • Size: 123.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gsbparse-0.5.2.tar.gz
Algorithm Hash digest
SHA256 ddcc797b7e5e45c4ec19a10ebf453b94b9b7ca68209c4a5367f8c01693ac50d9
MD5 33372a271f73007586ebda1cbfa5368a
BLAKE2b-256 7409000107fac7ecaa83fef616493e5928c752f0fa32b70d588d4b0105c2d3d9

See more details on using hashes here.

Provenance

The following attestation bundles were made for gsbparse-0.5.2.tar.gz:

Publisher: publish.yml on EBoisseauSierra/gsbparse

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

File details

Details for the file gsbparse-0.5.2-py3-none-any.whl.

File metadata

  • Download URL: gsbparse-0.5.2-py3-none-any.whl
  • Upload date:
  • Size: 62.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for gsbparse-0.5.2-py3-none-any.whl
Algorithm Hash digest
SHA256 d43d4fc0cb91b44553551ebc7c5a219637033c0ddc8b1ac2e703d4696434349c
MD5 11c5f5540c3ccaa9a211a7eefcafd7b6
BLAKE2b-256 35ab71fb69404c2421c3f126e11c82844c1b3113a8913b78df43e7b335a256c3

See more details on using hashes here.

Provenance

The following attestation bundles were made for gsbparse-0.5.2-py3-none-any.whl:

Publisher: publish.yml on EBoisseauSierra/gsbparse

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 Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page