stoier is the accounting helper toolkit.
This script reads Postbank bank statements and converts rows into dictionaries
Note: No deduplication of rows is done at this point!
The following command will read all CSVs in data/00_account
.
If the string gebuchte Umsätze is encountered in the first column of a row, the data will start
2 rows after that.
A custom header is used.
Results will be written to the dist
directory.
$ 00_csv_to_yml -v dist -t "0:gebuchte Umsätze:2" data/00_account/*.csv -h "date_1:date_2:type:details:sender:receiver:amount:balance" -r
Options: -v: verbose output -d: debug output -t: trigger; split head from body -h: header; add a custom csv header -r: read file in reverse order dist: out directory
Alternatively you could use the following command to skip only 1 row after the trigger and use the row after the trigger as header.
$ 00_csv_to_yml -v dist -t "0:gebuchte Umsätze:1" data/00_account/*.csv
This script removes control characters from data.
Note:
01_clean
will always select the latest file.
$ 01_clean -v dist dist/01_bookings
Options: -v: verbose output -d: debug output dist: out directory
Since this Postbank csv files have overlapping time slots, this scripts will deduplicate the records. Its writes to files: One with the unique bookings, one with all the customes. The customer file needs to be enriched manually with the "virtual account" they belong to, in our case mostly the interal customer reference number.
Note:
02_deduplicate
will always select the latest file.
All bookings between 1.1.2020 (incl.) and 31.12.2020 (incl.) will be added to the result.
$ 02_deduplicate -v dist dist/02_clean_bookings -s 01.01.2020 -e 31.12.2020
Options: -v: verbose output -d: debug output -s: start date -e: end date dist: out directory
This scripts returns a file which contains a sorted list of bookings, grouped by day. Each booking has a field
gross_accounts
(internal customer reference),ìd
(idetifier per day),net_accounts
vat
vat_account
Note:
03_validate
will always select the latest file.
$ 03_validate -d dist dist/03_unique_bookings
Options: -v: verbose output -d: debug output dist: out directory
This tool can help you to calculate your afa.
Create a yaml-file for each item/group/pool with the following format.
name: this_new_thing
description: The new black thing on the roof
date_of_purchase: 2019-01-23
price: 367.35
estimated_lifetime_years: 5
components:
- name: Housing
price: 154.23
- name: Components
price: 188.12
- name: Paint
price: 25.00
Note: Only name, description, date_of_purchase, price and estimated_lifetime_years are required. The rest is optional an can be used by you to take notes about components, purchases etc.
By default it will give the values for last year (as you need the current years afa less frequent this is the default).
$ 07_afa -v data/07_afa -y 2019
this_new_thing (The new black thing on the roof)
None: 73.470
Original price 367.350 (2019-01-23)
- Bootswatch Theme "vapor" by Thomas Park
- Bootstrap by Bootstrap Team
- stoier by Florian Rämisch