Python package source for KELLER protocol
Project description
keller-protocol - The KELLER Protocol (Python)
General Pre-requirement:
- A KELLER device is needed that can communicate with the Serial Port.
- ...with a USB-COM converter cable (eg.K114 series) AND the needed FTDI driver (https://www.ftdichip.com/Drivers/VCP.htm)
- ...or directly with a cable of the K-10X series
Installation
pip install keller-protocol
See https://pypi.org/project/keller-protocol/
Usage
See https://keller-druck.com/en/downloads?categories=Software.Communication-Protocols for the Communication Protocol.
- Import the Keller Protocol (keller_protocol.py) in your Python Project:
from keller_protocol import keller_protocol as kp
- Define Communication settings like port, baud-rate, timeout and echo:
transmitter = kp.KellerProtocol(
port="COM17", baud_rate=115200, timeout=0.2, echo=True
)
- To be able to communicate with the transmitter you will have to use F48 first to initialize. Otherwise, an exception occurs. F48 will return the firmware version. Make sure the device address is correct. (Default 1). If only one transmitter is connected, you can use the "transparent" address 250.
device_address = 1
firmware = transmitter.f48(device_address)
- Read out current pressure value from the transmitter. You will receive the pressure value P1 with channel 1.
p1 = transmitter.f73(device_address, 1)
Usage Example with X Line
import keller_protocol.keller_protocol as kp
import time
class XLine:
def __init__(self, port, baud_rate, address, timeout, echo=True):
self.bus = kp.KellerProtocol(port, baud_rate, timeout, echo)
self.address = address
self.serial_number = None
self.f73_channels = {
"CH0": 0,
"P1": 1,
"P2": 2,
"T": 3,
"TOB1": 4,
"TOB2": 5,
"ConTc": 10,
"ConRaw": 11,
}
self.init_f48()
def init_f48(self) -> str:
"""Initialise and release"""
answer = self.bus.f48(self.address)
print(f" Init of Device Address: {self.address} with Firmware: {answer}")
def get_serial(self) -> int:
"""Get Serial Number from X-Line
:returns Serial Number
"""
self.serial_number = self.bus.f69(self.address)
return self.serial_number
def get_address(self) -> int:
return self.address
def set_address(self, new_address: int) -> int:
"""Change the Device address. -> Has to be unique on the RS485 bus
:param new_address: New address of the Device
:return: If successful return new_address otherwise old address and throw exception
"""
self.address = self.bus.f66(self.address, new_address)
return self.address
def measure_tob1(self) -> float:
"""Get temperature TOB1
:return: temperature
"""
temperature = self.bus.f73(self.address, self.f73_channels["TOB1"])
return temperature
def measure_p1(self) -> float:
"""Get pressure P1
:return: pressure
"""
pressure = self.bus.f73(self.address, self.f73_channels["P1"])
return pressure
if __name__ == "__main__":
# Example usage:
# Init transmitter
transmitter = XLine(
port="COM17", baud_rate=115200, address=2, timeout=0.2, echo=True
)
serial_number = transmitter.get_serial()
print(f"Transmitter serial number:{serial_number}")
print("Press CTRL + C to quit")
while True:
try:
p1 = transmitter.measure_p1()
tob1 = transmitter.measure_tob1()
print(f"Pressure P1:{p1:.3f} Temperature TOB1:{tob1:.3f}")
time.sleep(1)
except KeyboardInterrupt:
print("Quit!")
break
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
keller_protocol-1.0.21.tar.gz
(7.6 kB
view hashes)
Built Distribution
Close
Hashes for keller_protocol-1.0.21-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8725ff6b403270be256edc0d4b5e5564dd730cdf7e04b9cb69e001baaecd20ad |
|
MD5 | fd5e5a61198e980f601af6634904b7df |
|
BLAKE2b-256 | a57881eb887ae773c164eb2dd4e84d8e9c7f14808d4d49c3539feb6a7c6554c3 |