MODBUS Controller for DEYE inverters
Project description
DEYE-controller
A library and simple tools for interaction with DEYE hybrid inverters
The communication with the inverter requires a SOLARMAN datalogger
pysloarmanv5 based library
- Command line tools (exposed after install):
deye-read - read everything from the inverter (use –help for filters/options)
deye-regcheck - for quick check on specific register(s)
deye-scan is a scanner for dataloggers in the local network (not DEYE related)
deye-regwrite - for writing to individual registers
- Monkey patching:
direct value assignment on read for the Register and RegistersGroup types (see the examples dir)
- Tested with:
SUN-12K-SG04LP3 / LSW-3
INSTALL
pip install deye-controller
TODO List
Support single phase inverters, eventually with auto detection.
Examples
After version 0.2.0 PySolarmanV5 can be patched for even easier reading see here
Basic usage:
read a register from the inverter
>>> from deye_controller import HoldingRegisters, WritableRegisters >>> from pysolarmanv5 import PySolarmanV5 >>> inv = PySolarmanV5('192.168.1.100', 2712345678) >>> register = HoldingRegisters.BMSBatteryCapacity >>> res = inv.read_holding_registers(register.address, register.len) >>> register.value = res[0] if register.len == 1 else res >>> print(register.description, register.format(), register.suffix) bms_battery_SOC 24 % >>> inv.disconnect()
write
>>> from deye_controller import HoldingRegisters, WritableRegisters >>> from pysolarmanv5 import PySolarmanV5 >>> inv = PySolarmanV5('192.168.1.100', 2712345678) >>> register = WritableRegisters.SellModeSOC3 >>> register.set(23) >>> inv.write_multiple_holding_registers(register.address, [register.modbus_value]) 1 >>> inv.disconnect()
SellMode programming:
>>> from deye_controller import SellProgrammer >>> prog = SellProgrammer('192.168.1.108', 2799999999) >>> prog.show_as_screen() ____________________________________________________ | Grid | Gen | Time | Pwr | SOC % | | | | 00:00 | 03:00 | 3500 | 100% | | | | 03:00 | 04:00 | 3500 | 30% | | | | 04:00 | 05:00 | 3500 | 30% | | | | 05:00 | 10:00 | 3500 | 30% | | | | 10:00 | 23:00 | 3500 | 100% | | | | 23:00 | 00:00 | 3500 | 30% | ---------------------------------------------------- >>> prog.update_program(3, start_t='6:30', power=2500, soc=35, grid_ch=True) Program updated >>> prog.show_as_screen() # For visual confirmation of the settings ____________________________________________________ | Grid | Gen | Time | Pwr | SOC % | | | | 00:00 | 03:00 | 3500 | 100% | | | | 03:00 | 04:00 | 3500 | 30% | | | | 04:00 | 06:30 | 3500 | 30% | | ✓ | | 06:30 | 10:00 | 2500 | 35% | | | | 10:00 | 23:00 | 3500 | 100% | | | | 23:00 | 00:00 | 3500 | 30% | ---------------------------------------------------- >>> prog.upload_settings() # In order to upload the settings to the inverter >>> prog.disconnect() # Needed if PySolarmanV5 >= 3.0.0
Notes
It is possible the inverter to be completely deactivated by writing 0 to register 80 WritableRegisters.SwitchOnOff.set(False) but it will raise an alarm and will show error F19. The normal state is restored as soon as the register is set to its default value 1.
The WritableRegisters.GridExportLimit register can be used if the grid export is not desired when the battery is charged and the PV generation exceeds the load.
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
Built Distribution
File details
Details for the file deye_controller-0.2.0.tar.gz
.
File metadata
- Download URL: deye_controller-0.2.0.tar.gz
- Upload date:
- Size: 39.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.9.9-lqx1-1-liquorix
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 297bd6e80eeab151d0464a062bbe57e7945857935de9df3270ff86d20c4fd681 |
|
MD5 | df9b765544b892aaa93f4d0200e25a0c |
|
BLAKE2b-256 | cc96d00461a3d1428413555b86b1707329c3cd44be7bcc07109ec7ae3f2b81aa |
File details
Details for the file deye_controller-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: deye_controller-0.2.0-py3-none-any.whl
- Upload date:
- Size: 22.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.3 CPython/3.10.14 Linux/6.9.9-lqx1-1-liquorix
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 473d67347e20d7f9ec459ea0e0db218e8a1a49144f2fb9babe9cee9ba4853e3c |
|
MD5 | bb40aa390e4f19255897fca34ecb7009 |
|
BLAKE2b-256 | 5bd4b8d2b53b4c0c5705120c41409ba9e16c1a4e1b2f101dcb8a1e552e9b023d |