This is a library for communicating with Omron NX and NJ industrial PLC and motion controllers using Ethernet/IP.
This software implements the core functionality of reading and writing numeric, Boolean, string, structure and array variables to an Omron NX or NJ controller using symbolic names. The read_variable and write_variable methods allow the programmer to use Python based data types to write to variables, as well as properly format the data received when reading variables. The example code below demonstrates how to establish the explicit Ethernet/IP connection and then read and write variables to a test project in the NJ or NX controller.
This package is on PyPI so the user can install using:
pip install aphyt
In order to connect to an Omron N-Series controller for data exchange using Ethernet/IP, the programmer should import omron from the aphyt module and instantiate an instance from the NSeries or NSeriesThreadDispatcher object using a context manager or by assignment. If the program supplies the host to the object, it is not necessary to explicitly connect to the IP address of the controller, and register a session. If the object is created without a host, the connection and session registration must be done explicitly.
import time
from aphyt import omron
if __name__ == '__main__':
with omron.NSeries('192.168.250.9') as eip_conn:
for i in range(10):
print(eip_conn.read_variable('TestInt'))
eip_conn.write_variable('TestInt', 24)
print(eip_conn.read_variable('TestInt'))
eip_conn.write_variable('TestInt', 7)
time.sleep(.5)