Skip to main content

Parser and query API for bank CSV account transactions

Project description

Elv

Wheel Status

Elv is a small module for parsing bank transactions from CSV files and performing queries on the data.

Supported formats

It currently supports the banks who use the Eike Alliance solution. These include, but are not limited to

  • Jæren Sparebank

  • Sandnes Sparebank

but I’ll add support for other banks whenever I get an example dump of their format. Send pull requests if you have them at https://github.com/cslarsen/elv/.

Sandnes Sparebank used to have another format, and I’ve kept it here, although I’m not sure anyone uses that anymore.

Norwegian short description

Elv er en Python modul for å lese banktransaksjoner eksportert fra banken din som en CSV-fil.

Foreløpig er det kun støtte for å lese filer fra Jæren Sparebank og Sandnes Sparebank. For å eksportere transaksjoner for en konto, velg et datointervall og deretter i øverste høyre ikon velger du “eksporter til fil”.

Jeg har sett at andre nettbanker har tilsvarende funksjonalitet, så send meg gjerne eksempler på andre format så skal jeg legge dem til.

Features

  • Parses CSV file from bank containing transactions

  • Money is stored in exact decimals

  • Contains a simple Python query API for sorting through large collections of transactions.

  • Can optionally put transactions in an in-memory SQLite3 database for even better queries.

Elevator pitch

Here’s how easy it is to use elv:

>>> from datetime import date
>>> import elv
>>> trans = elv.parse("data.csv")
>>> trans
<Transactions:453 items from 2009-01-27 to 2015-03-20>
>>> trans[0].amount
Decimal('300.00')
>>> trans.range(date(2015,1,1), date(2015,3,1))
<Transactions:15 items from 2015-01-02 to 2015-02-20>
>>> trans.range(date(2015,1,1), date(2015,3,1)).total()
Decimal('4500.00')

Installation

You can install from setup.py:

$ python setup.py install # you may have to run as sudo

or from PyPI:

$ pip install elv

Example usage

If you have the bank account transactions in a file called data.csv, you can simply do:

$ python
>>> import elv
>>> transactions = elv.parse("data.csv")
>>> transactions
<Transactions:400 items from 2009-01-27 to 2014-09-29>
>>> transactions[0]
<Transaction:2014-09-29 2014-09-29 -2677.00  29519.13 'Vacation'>
>>> transactions[0].xfer
datetime.date(2014, 9, 29)
>>> transactions[0].posted
datetime.date(2014, 9, 29)
>>> transactions[0].amount
Decimal('-2677.00')

You can also get an in-memory SQLite3 database by doing:

>>> db = transactions.to_sqlite3()
>>> db
<sqlite3.Connection object at 0x10f31e200>
>>> db.execute("SELECT * FROM Transactions").next()
(0, datetime.date(2014, 9, 29), datetime.date(2014, 9, 29),
 u'Vacation', Decimal('-2677'), Decimal('29519.13'))

How to parse other formats

To parse the default format, Jæren Sparebank:

>>> ts = elv.parse("file.csv", format="Jæren Sparebank")

To parse Sandnes Sparebank:

>>> ts = elv.parse("file.txt", format="Sandnes Sparebank")

To see a list of formats, see the dictionary elv.formats.

The CSV File Format: Jæren Sparebank

The CSV file should be a plain text file with the ISO-8859-1 encoding (aka Latin1). It looks like this:

"31-12-2014";"31-12-2014";"Test 1";"-497,78";"5.520,09"
"30-12-2014";"31-12-2014";"Test 2";"-100,00";"6.017,87"
"30-12-2014";"31-12-2014";"Test 3 --æøåÆØÅ--";"-145,47";"6.117,87"
"30-12-2014";"30-12-2014";"Test 4";"-457,24";"6.263,34"
"29-12-2014";"29-12-2014";"Test 5";"-108,30";"6.720,58"

The fields are as follows:

  • Date when the transaction was placed, in format "DD-MM-YYYY".

  • Date when the transaction was posted (“bokført”).

  • A message associated with the transaction, set by the one making the transaction.

  • The amount deposited or deducted from the account in NOK (Norwegian kroner) in format "-123,45", always two decimals and an optional sign.

  • The balance of your account after this transaction was completed.

The file itself contains no headers, and can contain many such transactions, one per line.

License

Copyright 2015, 2016 Christian Stigen Larsen

Licensed under Affero GPL v3 or later; see http://www.gnu.org/licenses/agpl-3.0.html

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

elv-1.0.14.tar.gz (22.3 kB view details)

Uploaded Source

Built Distribution

elv-1.0.14-py2.py3-none-any.whl (10.9 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file elv-1.0.14.tar.gz.

File metadata

  • Download URL: elv-1.0.14.tar.gz
  • Upload date:
  • Size: 22.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for elv-1.0.14.tar.gz
Algorithm Hash digest
SHA256 4718bc631c5c3cb194f65d7211a42273323aa47c75046e32be9bc052bf4de36f
MD5 ede13a3d93c791d4a73e77a2c6e510e1
BLAKE2b-256 60e82029adadb0df156e43026099cd056b3f3ec0e3b249830bfde569ee9313f5

See more details on using hashes here.

File details

Details for the file elv-1.0.14-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for elv-1.0.14-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 8d6b6c4b26d630aa374ae6750b76cd3679b7440c63100d8f49a376790a25845e
MD5 043044e03dee44e9541050e3389240a7
BLAKE2b-256 b25ca4f84072dfc279b2e83096060233a927d11b9857e7a0da96ee176262cbad

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