-
-
Notifications
You must be signed in to change notification settings - Fork 112
Modbus IO's from CSV Exports
Modbus IO works with CSV converts from Codesys CSV exports:
By addressing the registers and using the names IO helps with large Modbus registers to check the register's place and name.
Modebus-response-filter node:
data:image/s3,"s3://crabby-images/c34f0/c34f00e19b9d68331589a6208e42852092acdcab" alt="image"
In our example here, variable "bOperationActive" is expected to be in register 37. If the register number of "bOperationActive" changes after a new convert of CSV your export to JSON, then it may not be in that register anymore. The node will fail and inform you about that mistake.
data:image/s3,"s3://crabby-images/9b169/9b1691328c6ef34b430d96b569555f3fc5266c15" alt="image"
Before you can make use of this feature you need to create a JSON file from the CSV file you got from CODESYS:
data:image/s3,"s3://crabby-images/eabb1/eabb1f444e4981a94ed67a362894cdb27513d01f" alt="image"
You can find this flow in the Node-red flow examples. It takes an input CSV file and converts it to a JSON representation.
We want to get the variable name as name and the register name as valueAddress.
data:image/s3,"s3://crabby-images/d1541/d1541b12b77876dc679e6daf29c1e3eae357b4ea" alt="image"
Maybe you have to make a small change to the "Filter named Register" node to make it work for you CSV output:
if(msg.payload.col2 !== undefined && msg.payload.col2.indexOf('//') === -1) {
var varName = msg.payload.col2;
var varAddress = msg.payload.col3;
msg.payload = { 'name': varName, 'valueAddress': varAddress };
return msg;
}
This basically converts this:
Outputs;Modbus Input Registers;%QD30001;SDM 630 v2
Outputs[30001];fPhaseLine1NeutralVolts;%QD30001;SDM 630 v2
Outputs[30003];fPhaseLine2NeutralVolts;%QD30003;SDM 630 v2
Outputs[30005];fPhaseLine3NeutralVolts;%QD30005;SDM 630 v2
Outputs[30007];fPhase1Current;%QD30007;SDM 630 v2
Outputs[30009];fPhase2Current;%QD30009;SDM 630 v2
Outputs[30011];fPhase3Current;%QD30011;SDM 630 v2
to this:
{"name":"fPhaseLine1NeutralVolts","valueAddress":"%QD30001"}
{"name":"fPhaseLine2NeutralVolts","valueAddress":"%QD30003"}
{"name":"fPhaseLine3NeutralVolts","valueAddress":"%QD30005"}
{"name":"fPhase1Current","valueAddress":"%QD30007"}
{"name":"fPhase2Current","valueAddress":"%QD30009"}
{"name":"fPhase3Current","valueAddress":"%QD30011"}
data:image/s3,"s3://crabby-images/e65ca/e65caa6f808b0ea44356bd59ef5fd6a5cf24aa9b" alt="image"
data:image/s3,"s3://crabby-images/9e57b/9e57b82a63d68d202276d1bc283004d9853a75b1" alt="image"
The file location is based on a Windows system. When running Node-red in a docker image you might want to put the sdm630.CSV and JSON files in a folder like /usr/src/node-red ore something.
The IO-Config calcualtes the offsets from the variable prefixes like this:
{"payload":[
{"register":"MB-OUTPUTS","name":"fPhaseLine1NeutralVolts","addressStart":30001,"addressOffset":2,"addressOffsetIO":0,"addressStartIO":30001,"registerAddress":30001,"coilStart":0,"bitAddress":null,"Bit":0,"bits":32,"dataType":"Float","type":"output"},
{"register":"MB-OUTPUTS","name":"fPhaseLine2NeutralVolts","addressStart":30003,"addressOffset":2,"addressOffsetIO":0,"addressStartIO":30003,"registerAddress":30003,"coilStart":0,"bitAddress":null,"Bit":0,"bits":32,"dataType":"Float","type":"output"},
{"register":"MB-OUTPUTS","name":"fPhaseLine3NeutralVolts","addressStart":30005,"addressOffset":2,"addressOffsetIO":0,"addressStartIO":30005,"registerAddress":30005,"coilStart":0,"bitAddress":null,"Bit":0,"bits":32,"dataType":"Float","type":"output"},
{"register":"MB-OUTPUTS","name":"fPhase1Current","addressStart":30007,"addressOffset":2,"addressOffsetIO":0,"addressStartIO":30007,"registerAddress":30007,"coilStart":0,"bitAddress":null,"Bit":0,"bits":32,"dataType":"Float","type":"output...
]
You can find this flow in the Node-red flow examples, but I'm afraid it's not working anymore.