-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathnda2csv.py
48 lines (40 loc) · 2.01 KB
/
nda2csv.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# -*- coding: utf-8 -*-
from pik import nda
from collections import defaultdict
import unicodecsv as csv
def by_account(txn_stream):
result = defaultdict(lambda: [])
for txn in txn_stream:
result[txn.iban].append(txn)
return result
def to_csv(fobj, account_iban, txns):
wr = csv.writer(fobj)
wr.writerow(["", "Tilinumero", account_iban])
wr.writerow(["Vastatili","Vienti","Kirjauspäivä","Arvopäivä","Maksupäivä","Määrä","Saaja/Maksaja","Tilinumero","BIC","Tapahtuma","Viite","Maksajan viite","Viesti","Kortinnumero","Kuitti"])
for txn in txns:
# Row is like:
# Vastatili,Vienti,Kirjauspäivä,Arvopäivä,Maksupäivä,Määrä,Saaja/Maksaja,Tilinumero,BIC,Tapahtuma,Viite,Maksajan viite,Viesti,Kortinnumero,Kuitti
wr.writerow(["", "", txn.ledger_date, txn.value_date, txn.payment_date, txn.cents/100.0, txn.name, txn.recipient_iban, txn.recipient_bic, txn.operation, txn.ref, "", txn.msg, txn.receipt])
def main():
import sys
if len(sys.argv) < 2:
print >> sys.stderr, "Usage: nda2csv.py <fname_pattern>"
print >> sys.stderr, ""
print >> sys.stderr, "Outputs CSV files in augmented Nordea CSV format based in input Nordea NDA transactions read from stdin"
print >> sys.stderr, "Each CSV is written into its own file"
print >> sys.stderr, ""
print >> sys.stderr, "Arguments:"
print >> sys.stderr, " fname_pattern: Output filename pattern, where %s will be replaced by account IBAN number"
print >> sys.stderr, ""
print >> sys.stderr, "Example: nda2csv.py < 2016.nda '2016_%s.csv'"
print >> sys.stderr, ""
sys.exit(1)
fname_pattern = sys.argv[1]
# map from account id to list of transactions ordered by time
account_txns = by_account(nda.transactions(sys.stdin))
for account, txns in account_txns.iteritems():
fname = fname_pattern % account
with open(fname, 'wb') as f:
to_csv(f, account, txns)
if __name__ == '__main__':
main()