Skip to main content

Python driver for RS-232/USB bench scales (Kern, Mettler-Toledo, etc.).

Project description

serial-scale-bench

Python driver for RS-232/USB commercial bench scales (Kern, Mettler-Toledo, etc.).

Supports two ASCII response protocols:

  • Protocol 1 — multi-line header responses (GS, NT, GT prefixes); typical of Kern and similar label-printing scales
  • Protocol 2 — single float line; minimal scales and simpler firmware

Protocol is auto-detected on first connection. A FastAPI HTTP server is included for running the scale as a networked service (e.g. LabWatch integration).

Install

Base (serial only):

pip install serial-scale-bench

With HTTP API server:

pip install "serial-scale-bench[api]"

Or editable from this repo:

pip install -e .

Usage

from serial_scale_bench import SerialScale

scale = SerialScale(port="/dev/ttyUSB0", baudrate=9600)
scale.tare()
weight = scale.get_weight()   # float grams or None
scale.close()

Auto-reconnect wrapper

from serial_scale_bench import AutoReconnectSerialScale

scale = AutoReconnectSerialScale(port="/dev/ttyUSB0")
weight = scale.get_weight()   # reconnects automatically on error

HTTP API server

Start a local REST server exposing the scale over HTTP:

python -m serial_scale_bench.entrypoint --device /dev/ttyUSB0 --port 8080 --scale-id bench1

Endpoints: GET /weight, POST /tare, POST /zero, GET /status, GET /ping.

API reference

Method Description
get_weight() Poll current weight (float or None)
tare() Send tare command
zero() Send zero command
set_tare_value(value) Set absolute tare
is_connected() True if serial port is open
is_responsive() True if scale responds to ping
close() Close serial connection

murineshiftwork integration

Planned: BenchScaleAdapter in murineshiftwork.logic.scale. Install with:

pip install "murineshiftwork[calibration]"

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

serial_scale_bench-0.2.1.tar.gz (7.8 kB view details)

Uploaded Source

Built Distribution

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

serial_scale_bench-0.2.1-py3-none-any.whl (9.2 kB view details)

Uploaded Python 3

File details

Details for the file serial_scale_bench-0.2.1.tar.gz.

File metadata

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

File hashes

Hashes for serial_scale_bench-0.2.1.tar.gz
Algorithm Hash digest
SHA256 6c17afad5480479d4b20ee1c29097b3ad2ca214f5ef843a0c849d62d87ab28fa
MD5 1a614ee01e975e1c6eab137649d1715b
BLAKE2b-256 cc4bfe7f9dcd3d1709d91bf98cb913ca19979850c97079d93059de8f5fb6d8bd

See more details on using hashes here.

Provenance

The following attestation bundles were made for serial_scale_bench-0.2.1.tar.gz:

Publisher: release.yml on MurineShiftWork/serial-scale-bench

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

File details

Details for the file serial_scale_bench-0.2.1-py3-none-any.whl.

File metadata

File hashes

Hashes for serial_scale_bench-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0ff48ed3022b6dfdddbb65dc88a58c39e709d2aad8ffb2725936af6596409835
MD5 e61b11b853772ede8b995655f06cb5f5
BLAKE2b-256 46b3d55e950c5842e2196734228e55ccf043f782e3f53f18d6b8a169db5559e6

See more details on using hashes here.

Provenance

The following attestation bundles were made for serial_scale_bench-0.2.1-py3-none-any.whl:

Publisher: release.yml on MurineShiftWork/serial-scale-bench

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