qifparse is a parser for Quicken interchange format files (.qif).
Even if the qif format is:
- quite old now
- not supported for import by Quicken any more,
- ambiguous in some data management (notably on dates)
it's still quite commonly used by many personal finance managers.
Here's a sample parsing:
>>> from qifparse.parser import QifParser
>>> qif = QifParser.parse(file('file.qif'))
>>> qif.get_accounts()
(<qifparse.qif.Account object at 0x16148d0>, <qifparse.qif.Account object at 0x1614850>)
>>> qif.accounts[0].name
'My Cash'
>>> qif.get_categories()
(<qifparse.qif.Category object at 0x15b3d10>, <qifparse.qif.Category object at 0x15b3450>)
>>> qif.accounts[0].get_transactions()
(<Transaction units=-6.5>, <Transaction units=-6.0>)
>>> str(qif)
'!Type:Cat\nNfood\nE\n^\nNfood:lunch\nE\n^\n!Account\nNMy Cash\nTCash\n^\n!Type:Cash...
...
Here's a sample of a structure creation:
>>> qif_obj = qif.Qif() >>> acc = qif.Account(name='My Cc', account_type='Bank') >>> qif_obj.add_account(acc) >>> cat = qif.Category(name='food') >>> qif_obj.add_category(cat) >>> tr1 = qif.Transaction(amount=0.55) >>> acc.add_transaction(tr1, header='!Type:Bank') >>> tr2 = qif.Transaction() >>> tr2.amount = -6.55 >>> tr2.to_account = 'Cash' >>> acc.add_transaction(tr2) >>> acc.add(tr2) >>> str(qif_obj) '!Type:Cat\nNfood\nE\n^\n!Account\nNMy Cc\nTBank\n^\n!Type:Bank\nD02/11/2013\nT... ...
For more informations about qif format: