Skip to main content

Library for working with Open Financial Exchange (OFX) data

Project description

https://travis-ci.org/csingley/ofxtools.svg?branch=master https://coveralls.io/repos/github/csingley/ofxtools/badge.svg?branch=master https://img.shields.io/badge/dependencies-None-green.svg https://badge.fury.io/py/ofxtools.svg https://img.shields.io/badge/python-3.6%20%7C%203.7-brightgreen.svg

ofxtools is a Python library for working with Open Financial Exchange (OFX) data - the standard format for downloading financial information from banks and stockbrokers. OFX data is widely provided by financial institutions so that their customers can import transactions into financial management software such as Quicken, Microsoft Money, or GnuCash.

If you want to download your transaction data outside of one of these programs - if you wish to develop a Python application to use this data - if you need to generate your own OFX-formatted data… ofxtools is for you!

What is it?

ofxtools requests, consumes and produces both OFXv1 (SGML) and OFXv2 (XML) formats. It converts serialized markup to/from native Python objects of the appropriate data type, while preserving structure. It also handles Quicken’s QFX format, although it ignores Intuit’s proprietary extension tags.

In a nutshell, ofxtools makes it simple to get OFX data and extract it, or export your data in OFX format.

ofxtools takes a comprehensive, standards-based approach to processing OFX. It targets compliance with the OFX specification, specifically OFX versions 1.6 and 2.03.

ofxtools Coverage of the OFX Specification
  • Section 7 (financial institution profile)

  • Section 8 (service activation; account information)

  • Section 9 (email over OFX)

  • Section 10 (recurring bank transfers)

  • Section 11 (banking)

  • Section 12 (bill pay)

  • Section 13 (investments)

This should cover the great majority of real-world OFX use cases. A particular focus of ofxtools is full support of the OFX investment message set, which has been somewhat neglected by the Python community.

The major item remaining on the ofxtools “to do” list is to implement the tax schemas. It’s currently a low priority to implement Section 14 (bill pay) or the extensions contained in OFX versions beyond 2.03, but you’re welcome to contribute code if you need these.

Some care has been taken with the data model to make it easily maintainable and extensible. The ofxtools.models subpackage contains simple, direct translations of the relevant sections of the OFX specification. Using existing models as templates, it’s quite straightforward to define new models and cover more of the spec as needed (the odd corner case notwithstanding).

More than 10 years’ worth of OFX data from various financial institutions has been run through the ofxtools parser, with the results checked. Test coverage is high.

Where is it?

Full documentation is available at Read the Docs.

For ease of installation, ofxtools is released on PyPI.

Development of ofxtools is centralized at GitHub, where you will find a bug tracker.

Installation Dependencies

ofxtools requires Python version 3.6+, and depends only on the standard libary (no external dependencies).

NOTE: As of version 0.6, ofxtools no longer supports Python version 2, which goes EOL 2020-01-01.

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

ofxtools-0.8.13.tar.gz (101.0 kB view details)

Uploaded Source

File details

Details for the file ofxtools-0.8.13.tar.gz.

File metadata

  • Download URL: ofxtools-0.8.13.tar.gz
  • Upload date:
  • Size: 101.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.1 CPython/3.6.3

File hashes

Hashes for ofxtools-0.8.13.tar.gz
Algorithm Hash digest
SHA256 e1471e744f51f116d0b143a7f6b02d3942556ac1ff2da696513cb678137e6754
MD5 4254a33c1f86b357be7660482bc636f3
BLAKE2b-256 cead7ef0b2d5e048cb44b29c82906f59ac0faea64fb9c96fb7350bd7d8ec60b5

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page