Skip to main content

A modern, strongly typed Modbus client library.

Project description

tModbus

Homepage Documentation GitHub License Release Python Versions Testing

About

A modern Python Modbus library that is fully typed and well-tested.

Modbus is based on the master/slave communication pattern. We choose to use the terminology client and server instead, as it is more clear.

Features

  • Pure Python library with minimal dependencies
  • Fully typed
  • Full test coverage
  • Support for Modbus TCP, RTU, ASCII and RTU-over-TCP clients
  • Support for TCP over SSL connections
  • Auto reconnect and retry functionality (which can be enabled optionally)
  • Extensible with custom Modbus functions and exception codes
  • Open source (BSD)

Supported function codes

  • Read coils (0x01)
  • Read discrete inputs (0x02)
  • Read holding registers (0x03)
  • Read input registers (0x04)
  • Write single coil (0x05)
  • Write single register (0x06)
  • Read exception status (0x07)
  • Write multiple coils (0x0F)
  • Write multiple registers (0x10)
  • Report server ID (0x11)
  • Read file record (0x14)
  • Write file record (0x15)
  • Mask write register (0x16)
  • Read/write multiple registers (0x17)
  • Read FIFO queue (0x18)
  • Read device identification (0x2B / 0x0E)

Examples

A simple example of an Async TCP client:

import asyncio

from tmodbus import create_async_tcp_client


async def main() -> None:
    """Show example of reading a Modbus register."""
    async with create_async_tcp_client("127.0.0.1", 502, unit_id=1) as client:
        response = await client.read_holding_registers(start_address=100, quantity=2)
        print("Contents of holding registers 100 and 101: ", response)


if __name__ == "__main__":
    asyncio.run(main())

Various examples for Modbus RTU and TCP can be found in the examples folder.

Dependencies

async-serial

This library uses serialx to access the serial port when using async RTU or ASCII.

Use pip install tmodbus[async-serial] to install.

Changelog & releases

This repository keeps a change log using GitHub's releases functionality. The format of the log is based on Keep a Changelog.

Releases are based on Semantic Versioning, and use the format of MAJOR.MINOR.PATCH. In a nutshell, the version will be incremented based on the following:

  • MAJOR: Incompatible or major changes.
  • MINOR: Backwards-compatible new features and enhancements.
  • PATCH: Backwards-compatible bugfixes and package updates.

Contributing

This is an active open-source project. We are always open to people who want to use the code or contribute to it.

We've set up a separate document for our contribution guidelines.

Thank you for being involved! :heart_eyes:

Setting up a development environment

This Python project is fully managed using the uv dependency manager.

You need at least:

  • Python 3.12+
  • uv

To install all packages, including all development requirements:

uv sync  --all-extras --dev

As this repository uses the pre-commit framework, all changes are linted and tested with each commit. You can run all checks and tests manually, using the following command:

uv run pre-commit run --all-files

To run just the Python tests:

uv run pytest

Protocol-Specification

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

tmodbus-0.3.0.tar.gz (93.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tmodbus-0.3.0-py3-none-any.whl (58.8 kB view details)

Uploaded Python 3

File details

Details for the file tmodbus-0.3.0.tar.gz.

File metadata

  • Download URL: tmodbus-0.3.0.tar.gz
  • Upload date:
  • Size: 93.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tmodbus-0.3.0.tar.gz
Algorithm Hash digest
SHA256 9ebcc43b8ca7551b819c0e21a3dd1faf0ff1a91550efb629dd79b12e78f4cfcc
MD5 bdd70e869b96b25ce053f586d7321806
BLAKE2b-256 a3f2bf85b9a830ae9874d53b60041389ef0f2115caa8705eaaba5689a666eb71

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmodbus-0.3.0.tar.gz:

Publisher: pypi-publish.yml on wlcrs/tmodbus

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file tmodbus-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: tmodbus-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 58.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for tmodbus-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 9775305a9287b5179126620b4109102660a1f7a6fbc734bb6ef01897bbf940b2
MD5 122f39d81a2e639e67082c71999b303e
BLAKE2b-256 83fffa24ee0380e6b23e45403f10d32fdd6fe1860c88c4012dd27e7aade2c54b

See more details on using hashes here.

Provenance

The following attestation bundles were made for tmodbus-0.3.0-py3-none-any.whl:

Publisher: pypi-publish.yml on wlcrs/tmodbus

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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