fitdecode


Namefitdecode JSON
Version 0.10.0 PyPI version JSON
download
home_pagehttps://github.com/polyvertex/fitdecode
SummaryFIT file parser and decoder
upload_time2021-09-12 15:55:26
maintainer
docs_urlNone
authorJean-Charles Lefebvre
requires_python>=3.6
licenseMIT
keywords fit ant file parse parser decode decoder
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI
coveralls test coverage No coveralls.
            =========
fitdecode
=========

.. image:: https://readthedocs.org/projects/fitdecode/badge/?version=latest
    :target: https://fitdecode.readthedocs.io/
    :alt: Latest Docs

.. image:: https://api.travis-ci.com/polyvertex/fitdecode.svg
    :target: https://app.travis-ci.com/github/polyvertex/fitdecode


A `FIT <https://developer.garmin.com/fit/overview/>`_ file parsing and decoding
library written in `Python3 <https://www.python.org/>`_ (``>= 3.6``).


Usage Example
=============

Read a FIT file, frame by frame:

.. code:: python

    import fitdecode

    with fitdecode.FitReader('file.fit') as fit:
        for frame in fit:
            # The yielded frame object is of one of the following types:
            # * fitdecode.FitHeader (FIT_FRAME_HEADER)
            # * fitdecode.FitDefinitionMessage (FIT_FRAME_DEFINITION)
            # * fitdecode.FitDataMessage (FIT_FRAME_DATA)
            # * fitdecode.FitCRC (FIT_FRAME_CRC)

            if frame.frame_type == fitdecode.FIT_FRAME_DATA:
                # Here, frame is a FitDataMessage object.
                # A FitDataMessage object contains decoded values that
                # are directly usable in your script logic.
                print(frame.name)


Command line utilities
----------------------

``fitjson`` exports JSON:

::

    $ fitjson --pretty -o out_file.json in_file.fit

To ease the introspection or your FIT files, ``fittxt`` exports to a dedicated
TXT format::

    $ fittxt -o out_file.txt in_file.fit

Both commands accept a ``--filter`` option (or ``-f``) which can be specified
multiples times::

    $ # include only RECORD messages:
    $ fitjson -f=record -o out_file.json in_file.fit

    $ # exclude FILE_ID and EVENT messages:
    $ fitjson -f=-file_id -f=-event -o out_file.json in_file.fit


Installation
============

fitdecode is available on `PyPI <https://pypi.org/project/fitdecode/>`_::

    $ pip install fitdecode


Or, to get the latest working version, you can clone fitdecode's `source code
repository <https://github.com/polyvertex/fitdecode>`_ before installing it::

    $ git clone git@github.com:polyvertex/fitdecode.git
    $ cd fitdecode
    $ python setup.py test     # optional step to run unit tests
    $ python setup.py install


Note that for convenience, the ``cmd`` directory located at the root of the
source code tree can safely be added to your ``PATH``, so that fitdecode
commands can be called without the package to be installed.


Overview
========

fitdecode is a non offensive and incompatible rewrite of the fitparse_ library,
with some improvements and additional features, as well as efforts made to
optimize both speed and memory usage.

Main differences between fitdecode and fitparse:

* fitdecode's API is not compatible with fitparse's

* fitdecode requires Python version 3.6 or greater

* fitdecode is faster

* fitdecode allows concurrent reading of multiple files by being thread-safe, in
  the sense that fitdecode's objects keep their state stored locally

* fitdecode does not discard the FIT header and the CRC footer while iterating
  a file, which allow to get a complete 1:1 representation of the file that is
  being read

* This also allows the client to easily deal with so-called chained FIT files,
  as per FIT SDK definition (i.e. concatenated FIT files)

* CRC computation and matching are both optional. CRC can be either matched, or
  only computed, or just ignored for faster reading.

* fitdecode offers optional access to records, headers and footers in their
  binary form, to allow FIT file cutting, stitching and filtering at binary
  level


Why a new library?
==================

A new library has been created instead of just offering to patch fitparse_
because many changes and adds in fitdecode break fitparse's backward
compatibilty and because it allowed more freedom during the development of
fitdecode.


Documentation
=============

Documentation is available at `<https://fitdecode.readthedocs.io/>`_


License
=======

This project is distributed under the terms of the MIT license.
See the `LICENSE.txt <LICENSE.txt>`_ file for details.


Credits
=======

fitdecode is largely based on the generic approach adopted by fitparse_ to
define FIT types and to decode raw values. That includes the module
``profile.py`` and all the classes it refers to, as well as the script
``generate_profile.py``.



.. _fitparse: https://github.com/dtcooper/python-fitparse


.. :changelog:

==========
Change Log
==========


v0.10.0 (2021-09-12)
====================

* ``fitjson``: added ``--pretty`` option
* ``fitjson``: added ``--nounk`` option to filter-out *unknown* messages
* ``fitjson``: ``--filter`` option also allows to filter-out messages
* ``fittxt``: ``--filter`` option also allows to filter-out messages
* ``fittxt``: added ``--nounk`` option to filter-out *unknown* messages
* Fixed: `FitReader` does not close a file-like object owned by the user
* Fixed: `FitReader.file_id` gets reset upon FIT footer (CRC frame)
* Fixed: `utils.get_mesg_num()` return value
* Fixed: `utils.get_mesg_field_num()` return value
* Minor corrections, improvements and code cleanup


v0.9.0 (2021-09-10)
===================

* `FitReader` gets new properties ``fit_file_index`` and ``fit_files_count``
* New ``CrcCheck`` policy: ``WARN``
* **BREAKING CHANGE:** ``CrcCheck`` default policy from ``RAISE`` to ``WARN``
* `FitHeaderError` exception messages a bit more helpful
* Minor corrections and code cleanup


v0.8.0 (2021-09-09)
===================

* `FitReader` gets the ``error_handling`` argument to be less strict on
  malformed files (issues #13, #16, #18)
* FIT SDK profile upgraded to v21.60
* Minor corrections, improvements and cleanup on code and documentation


v0.7.0 (2020-10-04)
===================

* Compatibility with Apple Watch improved (issue #10)
* FIT SDK profile upgraded to v21.38
* ``generate_profile`` utility now supports recent SDK file structure
* Minor improvements and cleanup on code and documentation


v0.6.0 (2019-11-02)
===================

* Added `FitReader.last_timestamp` property
* Fixed: `FitReader` was raising `KeyError` instead of `FitParseError` when a
  dev_type was not found
* `FitParseError` message contains more details upon malformed file in some
  cases
* FIT SDK profile upgraded to v21.16
* README's usage example slightly improved


v0.5.0 (2019-04-11)
===================

* Added `fitdecode.DataProcessorBase` class
* ``check_crc`` - the parameter to `fitdecode.FitReader`'s constructor - can now
  be either "enabled", "read-only" or "disabled" (issue #1)
* Minor speed improvements


v0.4.0 (2019-04-10)
===================

* Added `fitdecode.FitDataMessage.has_field`
* `fitdecode.FitDataMessage.get_fields` is now a generator
* `fitdecode.FitDataMessage.get_values` is now a generator
* `fitdecode.DefaultDataProcessor` now converts ``hr.event_timestamp`` values
  that were populated from ``hr.event_timestamp_12`` components to
  `datetime.datetime` objects for convenience
* ``fitjson`` and ``fittxt`` utilities:
  * Added support for input files with Unicode characters
  * Still write output file even if an error occurred while parsing FIT file
* Fixed handling of some FIT fields that are both scaled and components.
  See https://github.com/dtcooper/python-fitparse/issues/84
* Improved support for malformed FIT files.
  See https://github.com/dtcooper/python-fitparse/issues/62
* ``generate_profile`` utility slightly improved
* Added some unit tests
* Minor improvements and corrections


v0.3.0 (2018-07-27)
===================

* Added `fitdecode.utils.get_mesg_field`
* Added `fitdecode.utils.get_mesg_field_num`
* Minor improvements and corrections


v0.2.0 (2018-07-16)
===================

* Added `FieldData.name_or_num`
* Added `FitDataMessage.get_fields`
* Added `FitDataMessage.get_values`
* Improved `FitDataMessage.get_field` (*idx* arg)
* Improved `FitDataMessage.get_value` (*idx* arg)
* Completed documentation of `FitDataMessage`
* Improved documentation of `FieldData`
* `FitReader`'s internal state is reset as well after a `FitCRC` has been
  yielded (i.e. not only when a FIT header is about to be read), in order to
  avoid incorrect behavior due to malformed FIT stream


v0.1.0 (2018-07-14)
===================

* Added class property ``frame_type`` (read-only) to `FitHeader`, `FitCRC`,
  `FitDefinitionMessage` and `FitDataMessage` (``records`` module) to ease and
  speed up type checking
* Added `FitDataMessage.get_value` method
* ``string`` values with no null byte are still decoded (in full length)
* ``cmd`` directory added to the source code tree for convenience


v0.0.1 (2018-07-08)
===================

* First release


v0.0.0 (2018-05-31)
===================

* Birth!



            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/polyvertex/fitdecode",
    "name": "fitdecode",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.6",
    "maintainer_email": "",
    "keywords": "fit,ant,file,parse,parser,decode,decoder",
    "author": "Jean-Charles Lefebvre",
    "author_email": "polyvertex@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/9e/8c/7cf1d2865fc0d593dfd389704b751ca1ed2a98860c41d4587c5b49637da3/fitdecode-0.10.0.tar.gz",
    "platform": "",
    "description": "=========\nfitdecode\n=========\n\n.. image:: https://readthedocs.org/projects/fitdecode/badge/?version=latest\n    :target: https://fitdecode.readthedocs.io/\n    :alt: Latest Docs\n\n.. image:: https://api.travis-ci.com/polyvertex/fitdecode.svg\n    :target: https://app.travis-ci.com/github/polyvertex/fitdecode\n\n\nA `FIT <https://developer.garmin.com/fit/overview/>`_ file parsing and decoding\nlibrary written in `Python3 <https://www.python.org/>`_ (``>= 3.6``).\n\n\nUsage Example\n=============\n\nRead a FIT file, frame by frame:\n\n.. code:: python\n\n    import fitdecode\n\n    with fitdecode.FitReader('file.fit') as fit:\n        for frame in fit:\n            # The yielded frame object is of one of the following types:\n            # * fitdecode.FitHeader (FIT_FRAME_HEADER)\n            # * fitdecode.FitDefinitionMessage (FIT_FRAME_DEFINITION)\n            # * fitdecode.FitDataMessage (FIT_FRAME_DATA)\n            # * fitdecode.FitCRC (FIT_FRAME_CRC)\n\n            if frame.frame_type == fitdecode.FIT_FRAME_DATA:\n                # Here, frame is a FitDataMessage object.\n                # A FitDataMessage object contains decoded values that\n                # are directly usable in your script logic.\n                print(frame.name)\n\n\nCommand line utilities\n----------------------\n\n``fitjson`` exports JSON:\n\n::\n\n    $ fitjson --pretty -o out_file.json in_file.fit\n\nTo ease the introspection or your FIT files, ``fittxt`` exports to a dedicated\nTXT format::\n\n    $ fittxt -o out_file.txt in_file.fit\n\nBoth commands accept a ``--filter`` option (or ``-f``) which can be specified\nmultiples times::\n\n    $ # include only RECORD messages:\n    $ fitjson -f=record -o out_file.json in_file.fit\n\n    $ # exclude FILE_ID and EVENT messages:\n    $ fitjson -f=-file_id -f=-event -o out_file.json in_file.fit\n\n\nInstallation\n============\n\nfitdecode is available on `PyPI <https://pypi.org/project/fitdecode/>`_::\n\n    $ pip install fitdecode\n\n\nOr, to get the latest working version, you can clone fitdecode's `source code\nrepository <https://github.com/polyvertex/fitdecode>`_ before installing it::\n\n    $ git clone git@github.com:polyvertex/fitdecode.git\n    $ cd fitdecode\n    $ python setup.py test     # optional step to run unit tests\n    $ python setup.py install\n\n\nNote that for convenience, the ``cmd`` directory located at the root of the\nsource code tree can safely be added to your ``PATH``, so that fitdecode\ncommands can be called without the package to be installed.\n\n\nOverview\n========\n\nfitdecode is a non offensive and incompatible rewrite of the fitparse_ library,\nwith some improvements and additional features, as well as efforts made to\noptimize both speed and memory usage.\n\nMain differences between fitdecode and fitparse:\n\n* fitdecode's API is not compatible with fitparse's\n\n* fitdecode requires Python version 3.6 or greater\n\n* fitdecode is faster\n\n* fitdecode allows concurrent reading of multiple files by being thread-safe, in\n  the sense that fitdecode's objects keep their state stored locally\n\n* fitdecode does not discard the FIT header and the CRC footer while iterating\n  a file, which allow to get a complete 1:1 representation of the file that is\n  being read\n\n* This also allows the client to easily deal with so-called chained FIT files,\n  as per FIT SDK definition (i.e. concatenated FIT files)\n\n* CRC computation and matching are both optional. CRC can be either matched, or\n  only computed, or just ignored for faster reading.\n\n* fitdecode offers optional access to records, headers and footers in their\n  binary form, to allow FIT file cutting, stitching and filtering at binary\n  level\n\n\nWhy a new library?\n==================\n\nA new library has been created instead of just offering to patch fitparse_\nbecause many changes and adds in fitdecode break fitparse's backward\ncompatibilty and because it allowed more freedom during the development of\nfitdecode.\n\n\nDocumentation\n=============\n\nDocumentation is available at `<https://fitdecode.readthedocs.io/>`_\n\n\nLicense\n=======\n\nThis project is distributed under the terms of the MIT license.\nSee the `LICENSE.txt <LICENSE.txt>`_ file for details.\n\n\nCredits\n=======\n\nfitdecode is largely based on the generic approach adopted by fitparse_ to\ndefine FIT types and to decode raw values. That includes the module\n``profile.py`` and all the classes it refers to, as well as the script\n``generate_profile.py``.\n\n\n\n.. _fitparse: https://github.com/dtcooper/python-fitparse\n\n\n.. :changelog:\n\n==========\nChange Log\n==========\n\n\nv0.10.0 (2021-09-12)\n====================\n\n* ``fitjson``: added ``--pretty`` option\n* ``fitjson``: added ``--nounk`` option to filter-out *unknown* messages\n* ``fitjson``: ``--filter`` option also allows to filter-out messages\n* ``fittxt``: ``--filter`` option also allows to filter-out messages\n* ``fittxt``: added ``--nounk`` option to filter-out *unknown* messages\n* Fixed: `FitReader` does not close a file-like object owned by the user\n* Fixed: `FitReader.file_id` gets reset upon FIT footer (CRC frame)\n* Fixed: `utils.get_mesg_num()` return value\n* Fixed: `utils.get_mesg_field_num()` return value\n* Minor corrections, improvements and code cleanup\n\n\nv0.9.0 (2021-09-10)\n===================\n\n* `FitReader` gets new properties ``fit_file_index`` and ``fit_files_count``\n* New ``CrcCheck`` policy: ``WARN``\n* **BREAKING CHANGE:** ``CrcCheck`` default policy from ``RAISE`` to ``WARN``\n* `FitHeaderError` exception messages a bit more helpful\n* Minor corrections and code cleanup\n\n\nv0.8.0 (2021-09-09)\n===================\n\n* `FitReader` gets the ``error_handling`` argument to be less strict on\n  malformed files (issues #13, #16, #18)\n* FIT SDK profile upgraded to v21.60\n* Minor corrections, improvements and cleanup on code and documentation\n\n\nv0.7.0 (2020-10-04)\n===================\n\n* Compatibility with Apple Watch improved (issue #10)\n* FIT SDK profile upgraded to v21.38\n* ``generate_profile`` utility now supports recent SDK file structure\n* Minor improvements and cleanup on code and documentation\n\n\nv0.6.0 (2019-11-02)\n===================\n\n* Added `FitReader.last_timestamp` property\n* Fixed: `FitReader` was raising `KeyError` instead of `FitParseError` when a\n  dev_type was not found\n* `FitParseError` message contains more details upon malformed file in some\n  cases\n* FIT SDK profile upgraded to v21.16\n* README's usage example slightly improved\n\n\nv0.5.0 (2019-04-11)\n===================\n\n* Added `fitdecode.DataProcessorBase` class\n* ``check_crc`` - the parameter to `fitdecode.FitReader`'s constructor - can now\n  be either \"enabled\", \"read-only\" or \"disabled\" (issue #1)\n* Minor speed improvements\n\n\nv0.4.0 (2019-04-10)\n===================\n\n* Added `fitdecode.FitDataMessage.has_field`\n* `fitdecode.FitDataMessage.get_fields` is now a generator\n* `fitdecode.FitDataMessage.get_values` is now a generator\n* `fitdecode.DefaultDataProcessor` now converts ``hr.event_timestamp`` values\n  that were populated from ``hr.event_timestamp_12`` components to\n  `datetime.datetime` objects for convenience\n* ``fitjson`` and ``fittxt`` utilities:\n  * Added support for input files with Unicode characters\n  * Still write output file even if an error occurred while parsing FIT file\n* Fixed handling of some FIT fields that are both scaled and components.\n  See https://github.com/dtcooper/python-fitparse/issues/84\n* Improved support for malformed FIT files.\n  See https://github.com/dtcooper/python-fitparse/issues/62\n* ``generate_profile`` utility slightly improved\n* Added some unit tests\n* Minor improvements and corrections\n\n\nv0.3.0 (2018-07-27)\n===================\n\n* Added `fitdecode.utils.get_mesg_field`\n* Added `fitdecode.utils.get_mesg_field_num`\n* Minor improvements and corrections\n\n\nv0.2.0 (2018-07-16)\n===================\n\n* Added `FieldData.name_or_num`\n* Added `FitDataMessage.get_fields`\n* Added `FitDataMessage.get_values`\n* Improved `FitDataMessage.get_field` (*idx* arg)\n* Improved `FitDataMessage.get_value` (*idx* arg)\n* Completed documentation of `FitDataMessage`\n* Improved documentation of `FieldData`\n* `FitReader`'s internal state is reset as well after a `FitCRC` has been\n  yielded (i.e. not only when a FIT header is about to be read), in order to\n  avoid incorrect behavior due to malformed FIT stream\n\n\nv0.1.0 (2018-07-14)\n===================\n\n* Added class property ``frame_type`` (read-only) to `FitHeader`, `FitCRC`,\n  `FitDefinitionMessage` and `FitDataMessage` (``records`` module) to ease and\n  speed up type checking\n* Added `FitDataMessage.get_value` method\n* ``string`` values with no null byte are still decoded (in full length)\n* ``cmd`` directory added to the source code tree for convenience\n\n\nv0.0.1 (2018-07-08)\n===================\n\n* First release\n\n\nv0.0.0 (2018-05-31)\n===================\n\n* Birth!\n\n\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "FIT file parser and decoder",
    "version": "0.10.0",
    "split_keywords": [
        "fit",
        "ant",
        "file",
        "parse",
        "parser",
        "decode",
        "decoder"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "md5": "178d091ce1c49ecccf0d60289205ca62",
                "sha256": "527dc2e4b0fe45dbe868a2131af0a544cb686f631f608d94e392bcce57b047cf"
            },
            "downloads": -1,
            "filename": "fitdecode-0.10.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "178d091ce1c49ecccf0d60289205ca62",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.6",
            "size": 90890,
            "upload_time": "2021-09-12T15:55:23",
            "upload_time_iso_8601": "2021-09-12T15:55:23.979340Z",
            "url": "https://files.pythonhosted.org/packages/4b/de/cf0f223255bf12c885acdc3bcce7fdc5607db496d3e3b682c001a51406e0/fitdecode-0.10.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "md5": "f94a95169dd3af6cebd49f630c97081c",
                "sha256": "1b85d1303c87650c11377a7322757eaa1caf229776bbd5b545591dd6815123e4"
            },
            "downloads": -1,
            "filename": "fitdecode-0.10.0.tar.gz",
            "has_sig": false,
            "md5_digest": "f94a95169dd3af6cebd49f630c97081c",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.6",
            "size": 89048,
            "upload_time": "2021-09-12T15:55:26",
            "upload_time_iso_8601": "2021-09-12T15:55:26.830048Z",
            "url": "https://files.pythonhosted.org/packages/9e/8c/7cf1d2865fc0d593dfd389704b751ca1ed2a98860c41d4587c5b49637da3/fitdecode-0.10.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2021-09-12 15:55:26",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "github_user": "polyvertex",
    "github_project": "fitdecode",
    "travis_ci": true,
    "coveralls": false,
    "github_actions": false,
    "lcname": "fitdecode"
}
        
Elapsed time: 0.05630s