<div markdown="1" class="custom-badge-table">
| | |
| ----------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Testing** | [data:image/s3,"s3://crabby-images/9a8df/9a8dfc32b4efd637fea65daa6e558265ada459cb" alt="Code testing status"](https://github.com/tektronix/tm_data_types/actions/workflows/test-code.yml) [data:image/s3,"s3://crabby-images/19742/19742348dfe813e7fed7fcea2e4075c19fed51db" alt="Docs testing status"](https://github.com/tektronix/tm_data_types/actions/workflows/test-docs.yml) [data:image/s3,"s3://crabby-images/3f006/3f006be43ec041dfdb8e016f5b8ad1484802781b" alt="Coverage status"](https://codecov.io/gh/tektronix/tm_data_types) |
| **Code Quality** | [data:image/s3,"s3://crabby-images/bb4be/bb4beaa1e9f05818c4e51d049545e861c630d9e1" alt="CodeQL status"](https://github.com/tektronix/tm_data_types/actions/workflows/codeql-analysis.yml) [data:image/s3,"s3://crabby-images/e90de/e90de2ea677840dd611dba289a6cd901f7ef71b2" alt="CodeFactor grade"](https://www.codefactor.io/repository/github/tektronix/tm_data_types) [data:image/s3,"s3://crabby-images/f2310/f2310244a215e6576a4ce25cd94efb738bf3f750" alt="pre-commit status"](https://results.pre-commit.ci/latest/github/tektronix/tm_data_types/main) |
| **Package** | [data:image/s3,"s3://crabby-images/4cf03/4cf03af427c69b74506358d3b7eeaba42b3e0f41" alt="PyPI: Package status"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/800e6/800e6454d33920582fe54ef1ace4250bf0edc94f" alt="PyPI: Latest release version"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/6206d/6206dbed49d8eaea6885d703f294bad27379a260" alt="PyPI: Supported Python versions"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/9492a/9492a362b9b6ab7be7670aac83015fc09cdf39b8" alt="PyPI: Downloads"](https://pepy.tech/project/tm_data_types) [data:image/s3,"s3://crabby-images/4b8d7/4b8d757d2a3222b4939fe9c62bf5b41f094ba454" alt="License: Apache 2.0"](https://github.com/tektronix/tm_data_types/blob/main/LICENSE.md) [data:image/s3,"s3://crabby-images/b60c6/b60c6ec961fa78211d1c381cb61d31a92ce0bd89" alt="Package build status"](https://github.com/tektronix/tm_data_types/actions/workflows/package-build.yml) [data:image/s3,"s3://crabby-images/66b5b/66b5ba8a24a578915388be4eb66c894fc0f39867" alt="PyPI upload status"](https://github.com/tektronix/tm_data_types/actions/workflows/package-release.yml) |
| **Documentation** | [data:image/s3,"s3://crabby-images/24390/243908383b7948c379220710d3b8a42a2b2e29cb" alt="ReadtheDocs Status"](https://tm-data-types.readthedocs.io) |
| **Code Style** | [data:image/s3,"s3://crabby-images/d3aaa/d3aaab063899a4e34e7ecc1ffb3a95bd2e8e7450" alt="Test style: pytest"](https://github.com/pytest-dev/pytest) [data:image/s3,"s3://crabby-images/af5ad/af5ad44d7bebe0ddd5457a3c514a7f51666c1502" alt="Code style: ruff"](https://docs.astral.sh/ruff/formatter/) [data:image/s3,"s3://crabby-images/e1166/e1166c7ccbf8ef41bb7f99f45a91fa95300aff31" alt="Docstring style: google"](https://google.github.io/styleguide/pyguide.html) |
| **Linting** | [data:image/s3,"s3://crabby-images/8e291/8e2913e43349a8054fed7e52fc20e55a9c761245" alt="pre-commit enabled"](https://github.com/pre-commit/pre-commit) [data:image/s3,"s3://crabby-images/e637f/e637f3dfb349b58ee27feacfef2b54209a406a15" alt="Docstring formatter: docformatter"](https://github.com/PyCQA/docformatter)[data:image/s3,"s3://crabby-images/d19d3/d19d367236c0669c820a2b8835f09719f17c5fd3" alt="Linter: pylint"](https://github.com/pylint-dev/pylint) |
</div>
---
# tm_data_types: Test & Measurement Data Types
`tm_data_types` provides tools to convert, edit, and write waveform data from Test & Measurement devices.
It simplifies handling waveform formats like CSV, WFM, and BIN in Python.
`tm_data_types` can be used to:
- **Convert** CSV, WFM, and BIN format into a waveform object,
- **Add or edit** waveform metadata,
- **Write** a valid waveform object to a file.
## Supported File Formats
<div markdown="1" class="custom-table-center-cells support-table">
| Interface | File formats |
| --------- | ------------------ |
| Reader | **.csv, .wfm[^1]** |
| Writer | **.csv, .wfm[^1]** |
</div>
## Installation
```shell
pip install tm_data_types
```
## Basic Usage
### Write File
```python
from tm_data_types import AnalogWaveform, write_file
waveform = AnalogWaveform()
file_path = "waveform_1.wfm"
write_file(file_path, waveform)
```
### Read File
```python
from tm_data_types import read_file
file_path = "waveform_1.wfm"
waveform = read_file(file_path)
```
## Documentation
See the full documentation at <https://tm-data-types.readthedocs.io>
## Maintainers
Before reaching out to any maintainers directly, please first check if
your issue or question is already covered by any [open
issues](https://github.com/tektronix/tm_data_types/issues). If the issue or
question you have is not already covered, please [file a new
issue](https://github.com/tektronix/tm_data_types/issues/new/choose) or
start a
[discussion](https://github.com/tektronix/tm_data_types/discussions) and
the maintainers will review and respond there.
- <opensource@tektronix.com> - For open-source policy and license
questions.
## Contributing
Interested in contributing? Check out the [contributing guidelines](https://github.com/tektronix/tm_data_types/blob/main/CONTRIBUTING.md). Please
note that this project is released with a [Code of Conduct](https://github.com/tektronix/tm_data_types/blob/main/CODE_OF_CONDUCT.md). By
contributing to this project, you agree to abide by its terms.
## License
`tm_data_types` was created by Tektronix. It is licensed under the terms of
the [Apache License 2.0](https://github.com/tektronix/tm_data_types/blob/main/LICENSE.md).
## Security
The signatures of the files uploaded to [PyPI](https://pypi.org/project/tm_data_types/) and each
[GitHub Release](https://github.com/tektronix/tm_data_types/releases) can be verified using
the [GitHub CLI `attestation verify` command](https://cli.github.com/manual/gh_attestation_verify).
The artifact attestations can also be directly downloaded from the
[GitHub repo attestations page](https://github.com/tektronix/tm_data_types/attestations) if desired.
```shell
gh attestation verify --owner tektronix <file>
```
[^1]: Currently, `tm_data_types` only supports the [Tektronix proprietary `.wfm`](https://download.tek.com/manual/Waveform-File-Format-Manual-077022011.pdf) format. Support for other formats is planned for future releases.
Raw data
{
"_id": null,
"home_page": "https://pypi.org/project/tm_data_types/",
"name": "tm-data-types",
"maintainer": "Tektronix",
"docs_url": null,
"requires_python": "<4.0,>=3.8",
"maintainer_email": "opensource@tektronix.com",
"keywords": "Tektronix, Test & Measurement",
"author": "Tektronix",
"author_email": "opensource@tektronix.com",
"download_url": "https://files.pythonhosted.org/packages/69/ba/2724dc80dd65e99d3f22fdc4a5dcc15af2f5a40f8f0b1e065fc6fffc2d26/tm_data_types-0.1.1.tar.gz",
"platform": null,
"description": "<div markdown=\"1\" class=\"custom-badge-table\">\n\n| | |\n| ----------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |\n| **Testing** | [data:image/s3,"s3://crabby-images/9a8df/9a8dfc32b4efd637fea65daa6e558265ada459cb" alt="Code testing status"](https://github.com/tektronix/tm_data_types/actions/workflows/test-code.yml) [data:image/s3,"s3://crabby-images/19742/19742348dfe813e7fed7fcea2e4075c19fed51db" alt="Docs testing status"](https://github.com/tektronix/tm_data_types/actions/workflows/test-docs.yml) [data:image/s3,"s3://crabby-images/3f006/3f006be43ec041dfdb8e016f5b8ad1484802781b" alt="Coverage status"](https://codecov.io/gh/tektronix/tm_data_types) |\n| **Code Quality** | [data:image/s3,"s3://crabby-images/bb4be/bb4beaa1e9f05818c4e51d049545e861c630d9e1" alt="CodeQL status"](https://github.com/tektronix/tm_data_types/actions/workflows/codeql-analysis.yml) [data:image/s3,"s3://crabby-images/e90de/e90de2ea677840dd611dba289a6cd901f7ef71b2" alt="CodeFactor grade"](https://www.codefactor.io/repository/github/tektronix/tm_data_types) [data:image/s3,"s3://crabby-images/f2310/f2310244a215e6576a4ce25cd94efb738bf3f750" alt="pre-commit status"](https://results.pre-commit.ci/latest/github/tektronix/tm_data_types/main) |\n| **Package** | [data:image/s3,"s3://crabby-images/4cf03/4cf03af427c69b74506358d3b7eeaba42b3e0f41" alt="PyPI: Package status"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/800e6/800e6454d33920582fe54ef1ace4250bf0edc94f" alt="PyPI: Latest release version"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/6206d/6206dbed49d8eaea6885d703f294bad27379a260" alt="PyPI: Supported Python versions"](https://pypi.org/project/tm_data_types/) [data:image/s3,"s3://crabby-images/9492a/9492a362b9b6ab7be7670aac83015fc09cdf39b8" alt="PyPI: Downloads"](https://pepy.tech/project/tm_data_types) [data:image/s3,"s3://crabby-images/4b8d7/4b8d757d2a3222b4939fe9c62bf5b41f094ba454" alt="License: Apache 2.0"](https://github.com/tektronix/tm_data_types/blob/main/LICENSE.md) [data:image/s3,"s3://crabby-images/b60c6/b60c6ec961fa78211d1c381cb61d31a92ce0bd89" alt="Package build status"](https://github.com/tektronix/tm_data_types/actions/workflows/package-build.yml) [data:image/s3,"s3://crabby-images/66b5b/66b5ba8a24a578915388be4eb66c894fc0f39867" alt="PyPI upload status"](https://github.com/tektronix/tm_data_types/actions/workflows/package-release.yml) |\n| **Documentation** | [data:image/s3,"s3://crabby-images/24390/243908383b7948c379220710d3b8a42a2b2e29cb" alt="ReadtheDocs Status"](https://tm-data-types.readthedocs.io) |\n| **Code Style** | [data:image/s3,"s3://crabby-images/d3aaa/d3aaab063899a4e34e7ecc1ffb3a95bd2e8e7450" alt="Test style: pytest"](https://github.com/pytest-dev/pytest) [data:image/s3,"s3://crabby-images/af5ad/af5ad44d7bebe0ddd5457a3c514a7f51666c1502" alt="Code style: ruff"](https://docs.astral.sh/ruff/formatter/) [data:image/s3,"s3://crabby-images/e1166/e1166c7ccbf8ef41bb7f99f45a91fa95300aff31" alt="Docstring style: google"](https://google.github.io/styleguide/pyguide.html) |\n| **Linting** | [data:image/s3,"s3://crabby-images/8e291/8e2913e43349a8054fed7e52fc20e55a9c761245" alt="pre-commit enabled"](https://github.com/pre-commit/pre-commit) [data:image/s3,"s3://crabby-images/e637f/e637f3dfb349b58ee27feacfef2b54209a406a15" alt="Docstring formatter: docformatter"](https://github.com/PyCQA/docformatter)[data:image/s3,"s3://crabby-images/d19d3/d19d367236c0669c820a2b8835f09719f17c5fd3" alt="Linter: pylint"](https://github.com/pylint-dev/pylint) |\n\n</div>\n\n---\n\n# tm_data_types: Test & Measurement Data Types\n\n`tm_data_types` provides tools to convert, edit, and write waveform data from Test & Measurement devices.\nIt simplifies handling waveform formats like CSV, WFM, and BIN in Python.\n\n`tm_data_types` can be used to:\n\n- **Convert** CSV, WFM, and BIN format into a waveform object,\n- **Add or edit** waveform metadata,\n- **Write** a valid waveform object to a file.\n\n## Supported File Formats\n\n<div markdown=\"1\" class=\"custom-table-center-cells support-table\">\n\n| Interface | File formats |\n| --------- | ------------------ |\n| Reader | **.csv, .wfm[^1]** |\n| Writer | **.csv, .wfm[^1]** |\n\n</div>\n\n## Installation\n\n```shell\npip install tm_data_types\n```\n\n## Basic Usage\n\n### Write File\n\n```python\nfrom tm_data_types import AnalogWaveform, write_file\n\nwaveform = AnalogWaveform()\nfile_path = \"waveform_1.wfm\"\nwrite_file(file_path, waveform)\n```\n\n### Read File\n\n```python\nfrom tm_data_types import read_file\n\nfile_path = \"waveform_1.wfm\"\nwaveform = read_file(file_path)\n```\n\n## Documentation\n\nSee the full documentation at <https://tm-data-types.readthedocs.io>\n\n## Maintainers\n\nBefore reaching out to any maintainers directly, please first check if\nyour issue or question is already covered by any [open\nissues](https://github.com/tektronix/tm_data_types/issues). If the issue or\nquestion you have is not already covered, please [file a new\nissue](https://github.com/tektronix/tm_data_types/issues/new/choose) or\nstart a\n[discussion](https://github.com/tektronix/tm_data_types/discussions) and\nthe maintainers will review and respond there.\n\n- <opensource@tektronix.com> - For open-source policy and license\n questions.\n\n## Contributing\n\nInterested in contributing? Check out the [contributing guidelines](https://github.com/tektronix/tm_data_types/blob/main/CONTRIBUTING.md). Please\nnote that this project is released with a [Code of Conduct](https://github.com/tektronix/tm_data_types/blob/main/CODE_OF_CONDUCT.md). By\ncontributing to this project, you agree to abide by its terms.\n\n## License\n\n`tm_data_types` was created by Tektronix. It is licensed under the terms of\nthe [Apache License 2.0](https://github.com/tektronix/tm_data_types/blob/main/LICENSE.md).\n\n## Security\n\nThe signatures of the files uploaded to [PyPI](https://pypi.org/project/tm_data_types/) and each\n[GitHub Release](https://github.com/tektronix/tm_data_types/releases) can be verified using\nthe [GitHub CLI `attestation verify` command](https://cli.github.com/manual/gh_attestation_verify).\nThe artifact attestations can also be directly downloaded from the\n[GitHub repo attestations page](https://github.com/tektronix/tm_data_types/attestations) if desired.\n\n```shell\ngh attestation verify --owner tektronix <file>\n```\n\n[^1]: Currently, `tm_data_types` only supports the [Tektronix proprietary `.wfm`](https://download.tek.com/manual/Waveform-File-Format-Manual-077022011.pdf) format. Support for other formats is planned for future releases.\n\n",
"bugtrack_url": null,
"license": "Apache-2.0",
"summary": "Read and write common Test & Measurement data types.",
"version": "0.1.1",
"project_urls": {
"Bug Tracker": "https://github.com/tektronix/tm_data_types/issues",
"Changelog": "https://github.com/tektronix/tm_data_types/blob/main/CHANGELOG.md",
"Documentation": "https://tm-data-types.readthedocs.io",
"Homepage": "https://pypi.org/project/tm_data_types/",
"Repository": "https://github.com/tektronix/tm_data_types"
},
"split_keywords": [
"tektronix",
" test & measurement"
],
"urls": [
{
"comment_text": "",
"digests": {
"blake2b_256": "700a40fd564d8b84ef37673a41ecff8cb1d3a816aaba42e746966c34676330c8",
"md5": "12919ec6cd47581c20f14a8449566e4a",
"sha256": "9dee0f09ec087a56fd6c6680846487abc31f0c6e00efbd49e25fdebd4e5159ed"
},
"downloads": -1,
"filename": "tm_data_types-0.1.1-py3-none-any.whl",
"has_sig": false,
"md5_digest": "12919ec6cd47581c20f14a8449566e4a",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": "<4.0,>=3.8",
"size": 63892,
"upload_time": "2024-09-11T23:06:11",
"upload_time_iso_8601": "2024-09-11T23:06:11.659528Z",
"url": "https://files.pythonhosted.org/packages/70/0a/40fd564d8b84ef37673a41ecff8cb1d3a816aaba42e746966c34676330c8/tm_data_types-0.1.1-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": "",
"digests": {
"blake2b_256": "69ba2724dc80dd65e99d3f22fdc4a5dcc15af2f5a40f8f0b1e065fc6fffc2d26",
"md5": "26337e569aee08758dd4495161a09b53",
"sha256": "6a7178f497e12c028a417f0514b11bbff8873570b92a8d326956cf4438fef6c9"
},
"downloads": -1,
"filename": "tm_data_types-0.1.1.tar.gz",
"has_sig": false,
"md5_digest": "26337e569aee08758dd4495161a09b53",
"packagetype": "sdist",
"python_version": "source",
"requires_python": "<4.0,>=3.8",
"size": 49518,
"upload_time": "2024-09-11T23:06:13",
"upload_time_iso_8601": "2024-09-11T23:06:13.106060Z",
"url": "https://files.pythonhosted.org/packages/69/ba/2724dc80dd65e99d3f22fdc4a5dcc15af2f5a40f8f0b1e065fc6fffc2d26/tm_data_types-0.1.1.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2024-09-11 23:06:13",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "tektronix",
"github_project": "tm_data_types",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"lcname": "tm-data-types"
}