Skip to main content

The simple library for extracting all kind of bank account transaction export files, mostly for beanhub-import to inject and generate transactions

Project description

beanhub-extract CircleCI

The simple library for extracting all kind of bank account transaction export files, mostly for beanhub-import to ingest and generate transactions

Note: This project is still in early stage, still subject to rapid major changes

Why?

Have you ever wondered why each of us has to write our own different Beancount importers for the same bank again and again? Why we cannot use the same exporter for the same bank CSV file? One of the biggest problems of the original Beancount importer design is that the transaction generation logic is coupled with the extract logic, making it hard to reuse. We are addressing the problem by creating a library only for extracting bank-exported CSV files into standardized transaction structures to be processed later. Ideally, you should be able to import this library and use it to import standardized transactions from CSV files exported from any bank in the world.

Install

pip install beanhub-extract

Example

Extracting transactions from the CSV file is easy. Simply create the extractor class and make a function call on the instance object, which will return a transaction object generator. Like this:

from beanhub_extract.extractors.mercury import MercuryExtractor

with open("/path/to/my-mercury.csv", "rt") as fo:
    extractor = MercuryExtractor(fo)
    for txn in extractor():
        print(txn)
        # process your transaction here

Sponsor

BeanHub logo

A modern accounting book service based on the most popular open source version control system Git and text-based double entry accounting book software Beancount.

Transaction data object

We defined a standardized transaction data object to accommodate a transaction statement's most commonly used columns. The data object type is a simple immutable Python dataclasses.dataclass class. It's defined in the beanhub_extract/data_types.py file.

Supported Formats

Currently, we only support a few banks for our own benefit. If you find any particular bank CSV file or format missing and want this library to support it, please feel free to open a PR.

Mercury - mercury

To export the CSV file, please visit the Transactions page and click "Add Filter" to limit the time range of your export, then click the "Export All" button on the right-hand side.

Chase

Chase Credit Card - chase_credit_card

To export the Chase Credit Card CSV file, please visit and login the Chase website. Expand the credit card details by clicking on the card you would like to export. Click the "Download account activity" button on the right hand side of the Account activity section. Click the "Download" button after you select the activity time range to "Year to date".

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

beanhub_extract-0.1.3.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

beanhub_extract-0.1.3-py3-none-any.whl (9.9 kB view details)

Uploaded Python 3

File details

Details for the file beanhub_extract-0.1.3.tar.gz.

File metadata

  • Download URL: beanhub_extract-0.1.3.tar.gz
  • Upload date:
  • Size: 7.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1057-aws

File hashes

Hashes for beanhub_extract-0.1.3.tar.gz
Algorithm Hash digest
SHA256 7b3799ae436fcea23b8f33eb97012e6ac04b2381f2f7636eeca30bb43e0a3a01
MD5 69f640adff4bd5fd033f15e8f369e3d4
BLAKE2b-256 6f4a9bf69e11bd5f95fef558b2d88786236f7c983b34ccdfd9d4510defb5d8ea

See more details on using hashes here.

File details

Details for the file beanhub_extract-0.1.3-py3-none-any.whl.

File metadata

  • Download URL: beanhub_extract-0.1.3-py3-none-any.whl
  • Upload date:
  • Size: 9.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.11 Linux/5.15.0-1057-aws

File hashes

Hashes for beanhub_extract-0.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 f88dbf76fcf0cea87c8160db3934c1eaedab3b0233fecf2e03b59a9fe55339ec
MD5 858898bc97be9051926592fb532bd0bc
BLAKE2b-256 e7bccc3b21e0f53279ca4bf7408216a6312b1b2d42154789e0c3c16445bca35e

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