npTDMS


NamenpTDMS JSON
Version 1.9.0 PyPI version JSON
download
home_pagehttps://github.com/adamreeve/npTDMS
SummaryCross-platform, NumPy based module for reading TDMS files produced by LabView
upload_time2024-03-20 22:43:33
maintainerNone
docs_urlNone
authorAdam Reeve
requires_pythonNone
licenseLGPL
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage
            npTDMS
======

.. image:: https://img.shields.io/pypi/v/npTDMS.svg
    :alt: PyPI Version
    :target: https://pypi.org/project/npTDMS/
.. image:: https://github.com/adamreeve/npTDMS/actions/workflows/ci-cd.yml/badge.svg?branch=master&event=push
    :alt: Build status
    :target: https://github.com/adamreeve/npTDMS/actions/workflows/ci-cd.yml?query=event%3Apush+branch%3Amaster
.. image:: https://readthedocs.org/projects/nptdms/badge/?version=latest
    :target: https://nptdms.readthedocs.io/en/latest/?badge=latest
    :alt: Documentation Status
.. image:: https://codecov.io/gh/adamreeve/npTDMS/branch/master/graph/badge.svg
    :target: https://codecov.io/gh/adamreeve/npTDMS
    :alt: Code coverage


npTDMS is a cross-platform Python package for reading and writing TDMS files as produced by LabVIEW,
and is built on top of the `numpy <http://www.numpy.org/>`__ package.
Data is read from TDMS files as numpy arrays,
and npTDMS also allows writing numpy arrays to TDMS files.

TDMS files are structured in a hierarchy of groups and channels.
A TDMS file can contain multiple groups, which may each contain multiple channels.
A file, group and channel may all have properties associated with them,
but only channels have array data.

Typical usage when reading a TDMS file might look like::

    from nptdms import TdmsFile

    tdms_file = TdmsFile.read("path_to_file.tdms")
    group = tdms_file['group name']
    channel = group['channel name']
    channel_data = channel[:]
    channel_properties = channel.properties

The ``TdmsFile.read`` method reads all data into memory immediately.
When you are working with large TDMS files or don't need to read all channel data,
you can instead use ``TdmsFile.open``. This is more memory efficient but
accessing data can be slower::

    with TdmsFile.open("path_to_file.tdms") as tdms_file:
        group = tdms_file['group name']
        channel = group['channel name']
        channel_data = channel[:]

npTDMS also has rudimentary support for writing TDMS files.
Using npTDMS to write a TDMS file looks like::

    from nptdms import TdmsWriter, ChannelObject
    import numpy

    with TdmsWriter("path_to_file.tdms") as tdms_writer:
        data_array = numpy.linspace(0, 1, 10)
        channel = ChannelObject('group name', 'channel name', data_array)
        tdms_writer.write_segment([channel])

For more detailed documentation on reading and writing TDMS files,
see the `npTDMS documentation <http://nptdms.readthedocs.io>`__.

Installation
------------

npTDMS is available from the Python Package Index, so the easiest way to
install it is by running::

    pip install npTDMS

There are optional features available that require additional dependencies.
These are `hdf` for hdf export, `pandas` for pandas DataFrame export, and
`thermocouple_scaling` for using thermocouple scalings. You can specify these
extra features when installing npTDMS to also install the dependencies they
require::

    pip install npTDMS[hdf,pandas,thermocouple_scaling]

Alternatively, after downloading the source code you can extract it and
change into the new directory, then run::

    python setup.py install

Links
-----

Source code lives at https://github.com/adamreeve/npTDMS and any issues can be
reported at https://github.com/adamreeve/npTDMS/issues.
Documentation is available at http://nptdms.readthedocs.io.

Limitations
-----------

This module doesn't support TDMS files with XML headers or with
extended precision floating point data.

Contributors/Thanks
-------------------

Thanks to Floris van Vugt who wrote the pyTDMS module,
which helped when writing this module.

Thanks to Tony Perkins, Ruben De Smet, Martin Hochwallner and Peter Duncan
for contributing support for converting to Pandas DataFrames.

Thanks to nmgeek and jshridha for implementing support for DAQmx raw data
files.

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/adamreeve/npTDMS",
    "name": "npTDMS",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": null,
    "author": "Adam Reeve",
    "author_email": "adreeve@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/ff/05/8f560020155c1843d664248fb114e33eac0c1b3ad44fce6bfc2b5dd143c2/npTDMS-1.9.0.tar.gz",
    "platform": null,
    "description": "npTDMS\n======\n\n.. image:: https://img.shields.io/pypi/v/npTDMS.svg\n    :alt: PyPI Version\n    :target: https://pypi.org/project/npTDMS/\n.. image:: https://github.com/adamreeve/npTDMS/actions/workflows/ci-cd.yml/badge.svg?branch=master&event=push\n    :alt: Build status\n    :target: https://github.com/adamreeve/npTDMS/actions/workflows/ci-cd.yml?query=event%3Apush+branch%3Amaster\n.. image:: https://readthedocs.org/projects/nptdms/badge/?version=latest\n    :target: https://nptdms.readthedocs.io/en/latest/?badge=latest\n    :alt: Documentation Status\n.. image:: https://codecov.io/gh/adamreeve/npTDMS/branch/master/graph/badge.svg\n    :target: https://codecov.io/gh/adamreeve/npTDMS\n    :alt: Code coverage\n\n\nnpTDMS is a cross-platform Python package for reading and writing TDMS files as produced by LabVIEW,\nand is built on top of the `numpy <http://www.numpy.org/>`__ package.\nData is read from TDMS files as numpy arrays,\nand npTDMS also allows writing numpy arrays to TDMS files.\n\nTDMS files are structured in a hierarchy of groups and channels.\nA TDMS file can contain multiple groups, which may each contain multiple channels.\nA file, group and channel may all have properties associated with them,\nbut only channels have array data.\n\nTypical usage when reading a TDMS file might look like::\n\n    from nptdms import TdmsFile\n\n    tdms_file = TdmsFile.read(\"path_to_file.tdms\")\n    group = tdms_file['group name']\n    channel = group['channel name']\n    channel_data = channel[:]\n    channel_properties = channel.properties\n\nThe ``TdmsFile.read`` method reads all data into memory immediately.\nWhen you are working with large TDMS files or don't need to read all channel data,\nyou can instead use ``TdmsFile.open``. This is more memory efficient but\naccessing data can be slower::\n\n    with TdmsFile.open(\"path_to_file.tdms\") as tdms_file:\n        group = tdms_file['group name']\n        channel = group['channel name']\n        channel_data = channel[:]\n\nnpTDMS also has rudimentary support for writing TDMS files.\nUsing npTDMS to write a TDMS file looks like::\n\n    from nptdms import TdmsWriter, ChannelObject\n    import numpy\n\n    with TdmsWriter(\"path_to_file.tdms\") as tdms_writer:\n        data_array = numpy.linspace(0, 1, 10)\n        channel = ChannelObject('group name', 'channel name', data_array)\n        tdms_writer.write_segment([channel])\n\nFor more detailed documentation on reading and writing TDMS files,\nsee the `npTDMS documentation <http://nptdms.readthedocs.io>`__.\n\nInstallation\n------------\n\nnpTDMS is available from the Python Package Index, so the easiest way to\ninstall it is by running::\n\n    pip install npTDMS\n\nThere are optional features available that require additional dependencies.\nThese are `hdf` for hdf export, `pandas` for pandas DataFrame export, and\n`thermocouple_scaling` for using thermocouple scalings. You can specify these\nextra features when installing npTDMS to also install the dependencies they\nrequire::\n\n    pip install npTDMS[hdf,pandas,thermocouple_scaling]\n\nAlternatively, after downloading the source code you can extract it and\nchange into the new directory, then run::\n\n    python setup.py install\n\nLinks\n-----\n\nSource code lives at https://github.com/adamreeve/npTDMS and any issues can be\nreported at https://github.com/adamreeve/npTDMS/issues.\nDocumentation is available at http://nptdms.readthedocs.io.\n\nLimitations\n-----------\n\nThis module doesn't support TDMS files with XML headers or with\nextended precision floating point data.\n\nContributors/Thanks\n-------------------\n\nThanks to Floris van Vugt who wrote the pyTDMS module,\nwhich helped when writing this module.\n\nThanks to Tony Perkins, Ruben De Smet, Martin Hochwallner and Peter Duncan\nfor contributing support for converting to Pandas DataFrames.\n\nThanks to nmgeek and jshridha for implementing support for DAQmx raw data\nfiles.\n",
    "bugtrack_url": null,
    "license": "LGPL",
    "summary": "Cross-platform, NumPy based module for reading TDMS files produced by LabView",
    "version": "1.9.0",
    "project_urls": {
        "Homepage": "https://github.com/adamreeve/npTDMS"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ff058f560020155c1843d664248fb114e33eac0c1b3ad44fce6bfc2b5dd143c2",
                "md5": "48f8acf501eb91f1ca5aae2cf3006e7e",
                "sha256": "0e65c237e9d50b9b8e162b9c34171353a5ea05f4019c99c3e8ebc00722361cbc"
            },
            "downloads": -1,
            "filename": "npTDMS-1.9.0.tar.gz",
            "has_sig": false,
            "md5_digest": "48f8acf501eb91f1ca5aae2cf3006e7e",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 180644,
            "upload_time": "2024-03-20T22:43:33",
            "upload_time_iso_8601": "2024-03-20T22:43:33.902264Z",
            "url": "https://files.pythonhosted.org/packages/ff/05/8f560020155c1843d664248fb114e33eac0c1b3ad44fce6bfc2b5dd143c2/npTDMS-1.9.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-03-20 22:43:33",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "adamreeve",
    "github_project": "npTDMS",
    "travis_ci": false,
    "coveralls": true,
    "github_actions": true,
    "tox": true,
    "lcname": "nptdms"
}
        
Elapsed time: 0.24928s