Relay read counters

 1'''
 2Relay - Relay_read_counters.py with asynchronous mode.
 3
 4This example demonstrates how to read counters from EthanL.
 5
 6-------------------------------------------------------------------------------------
 7Please change correct serial number or IP and port number BEFORE you run example code.
 8
 9For other examples please check:
10    https://github.com/WPC-Systems-Ltd/WPC_Python_driver_release/tree/main/examples
11See README.md file to get detailed usage of this example.
12
13Copyright (c) 2022-2024 WPC Systems Ltd. All rights reserved.
14'''
15
16## Python
17import asyncio
18
19## WPC
20
21from wpcsys import pywpc
22
23async def main():
24    ## Get Python driver version
25    print(f'{pywpc.PKG_FULL_NAME} - Version {pywpc.__version__}')
26
27    ## Create device handle
28    dev = pywpc.EthanL()
29
30    ## Connect to device
31    try:
32        dev.connect("192.168.1.110") ## Depend on your device
33    except Exception as err:
34        pywpc.printGenericError(err)
35        ## Release device handle
36        dev.close()
37        return
38
39    try:
40        ## Parameters setting
41        port = 0 ## Depend on your device
42        index = -1 ## Read all the relay counters
43
44        ## Get firmware model & version
45        driver_info = await dev.Sys_getDriverInfo_async()
46        print("Model name: " + driver_info[0])
47        print("Firmware version: " + driver_info[-1])
48
49        ## open relay
50        err = await dev.Relay_open_async(port)
51        print(f"Relay_open_async in port {port}, status: {err}")
52
53        ## Read counters
54        counter = await dev.Relay_read_async(port, index)
55        print(f"Relay_read_async in port {port}: {counter}")
56
57        ## Close relay
58        err = await dev.Relay_close_async(port)
59        print(f"Relay_close_async in port {port}, status: {err}")
60    except Exception as err:
61        pywpc.printGenericError(err)
62
63    ## Disconnect device
64    dev.disconnect()
65
66    ## Release device handle
67    dev.close()
68
69    return
70
71def main_for_spyder(*args):
72    if asyncio.get_event_loop().is_running():
73        return asyncio.create_task(main(*args)).result()
74    else:
75        return asyncio.run(main(*args))
76
77if __name__ == '__main__':
78    asyncio.run(main()) ## Use terminal
79    # await main() ## Use Jupyter or IPython(>=7.0)
80    # main_for_spyder() ## Use Spyder