importing_device_servers_with_a_spreadsheet

Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
importing_device_servers_with_a_spreadsheet [2023/02/01 16:45]
wikiadmin [Special Parameters (Expert)]
importing_device_servers_with_a_spreadsheet [2023/02/02 22:34] (current)
wikiadmin [Importing into TransSECS Devices Node]
Line 1: Line 1:
 =====Importing into TransSECS Devices Node===== =====Importing into TransSECS Devices Node=====
  
-A list of servers for a specific Device may be added by right clicking on the Device name and using **Import Excel**.+A list of servers for a specific Device may be added by right clicking on the Device name and using **Import Excel**. Some things to keep in mind when setting up and using your spreadsheet to add device servers: 
 + 
 +1. There must be a tab ("sheet") called "devices" in your spreadsheet. The **Import Excel** operation will only read from this sheet with this name. 
 + 
 +2. Tag names (the ServerName property) cannot start with a number and do not put spaces or other non-alphanumeric characters in this field. Do not re-use any names already used as server names for any other item in the devices node. 
 + 
 +3. Cells can be empty. You do not need to enter the default values. Empty cells will use the default when adding new servers or will not change values you have set manually if you re-import the spreadsheet (values will not be overwritten unless you have a non empty value in the cell). 
 + 
 +4. Use the minimal number of columns in your spreadsheet. In other words, do not add columns for parameters you are not going to use or if you only use the defaults for the parameter value. For example, all servers have a timebase and the default is 1.0 second. Do not add a column for timebase unless you plan to change the defaults on one or more of your servers. 
 + 
 +5. You can define severs in more than one spreadsheet and import them separately. For example, if you want to separate your tags into servers for alarms, servers for data values, and servers for events, you can make three spreadsheets. This is not mandatory but might help with organization. 
 + 
 +6. Re-importing the spreadsheet will override any values in the server. A blank entry in the cell will result in the default value for that property.
  
 ====Demo Servers==== ====Demo Servers====
Line 26: Line 38:
 [[https://www.ergotech.com/files/examples/spreadsheets/DemoServersTest.xlsx|Example DemoServers Spreadsheet]] [[https://www.ergotech.com/files/examples/spreadsheets/DemoServersTest.xlsx|Example DemoServers Spreadsheet]]
  
-====Modbus PLC Registers====+=====Modbus PLC Registers=====
  
 Spreadsheet header example (order of column headers does not matter). The "note" heading is not used, so you can put text in that cell for your own reference. Spreadsheet header example (order of column headers does not matter). The "note" heading is not used, so you can put text in that cell for your own reference.
Line 38: Line 50:
  
 **ServerType:** the class of the server. One of: Modbus 0x Reg, Modbus Word, Modbus Double Word, Modbus Float, Modbus String, Modbus 1x Reg, Modbus Array, or Modbus String Array. These are entered as a whole string in the spreadsheet cell, i.e., "Modbus Word". **ServerType:** the class of the server. One of: Modbus 0x Reg, Modbus Word, Modbus Double Word, Modbus Float, Modbus String, Modbus 1x Reg, Modbus Array, or Modbus String Array. These are entered as a whole string in the spreadsheet cell, i.e., "Modbus Word".
 +
 +Enter the type into the cell exactly as shown below:
 +
 +<code>
 +Modbus Word
 +Modbus Double Word
 +Modbus Float
 +Modbus String
 +Modbus Array
 +Modbus String Array
 +Modbus 0x Reg
 +Modbus 1x Reg
 +Modbus Preset Word
 +</code>
  
 Each server type may need optional parameters (not used for other server types, for example SwapStyle for ModbusFloat is only used for ModbusFloat and no other server type). If you want to use an optional parameter (and not use its default value), then add an additional column to the spreadsheet and enter the parameter value for this specific server. All other rows (for other server types) should be left empty. Each server type may need optional parameters (not used for other server types, for example SwapStyle for ModbusFloat is only used for ModbusFloat and no other server type). If you want to use an optional parameter (and not use its default value), then add an additional column to the spreadsheet and enter the parameter value for this specific server. All other rows (for other server types) should be left empty.
Line 47: Line 73:
 **StationAddress:** the slave node address (station address). This defaults to 0 if not set to a different value such as 1. **StationAddress:** the slave node address (station address). This defaults to 0 if not set to a different value such as 1.
  
-**RegType:** the register type defaults to 4X (holding register, read/write) but can be changed to 3X (input register, read only). This defaults to "4" but can be set to "3" for 3X register types. This is only used for all Modbus Server Types except Modbus 0X Reg and Modbus 1X Reg. If not set (blank in the spreadsheet cell) the default 4X will be used.+**RegisterType:** the register type defaults to 4X (holding register, read/write) but can be changed to 3X (input register, read only). This defaults to "4" but can be set to "3" for 3X register types. This is only used for all Modbus Server Types except Modbus 0X Reg and Modbus 1X Reg. If not set (blank in the spreadsheet cell) the default 4X will be used.
  
-**//Special Parameters (Expert)//**+**//Special Parameters (not commonly changed from defaults)//**
  
 **OptimizeReads:** This defaults to "true" so that registers are read in blocks. If OptimizeReads is set to false for this server then this register will be read individually at the set timebase interval. **OptimizeReads:** This defaults to "true" so that registers are read in blocks. If OptimizeReads is set to false for this server then this register will be read individually at the set timebase interval.
Line 55: Line 81:
 **TriggerOnThread:** This defaults to true and only effectively applies to timebase=0 servers that are being triggered for a read if set to false. Otherwise the server value will be updated on the block read "thread". **TriggerOnThread:** This defaults to true and only effectively applies to timebase=0 servers that are being triggered for a read if set to false. Otherwise the server value will be updated on the block read "thread".
  
-== Word and Double Word Parameters ==+==== Word and Double Word Parameters ====
  
 **Signed:** Signed is used for Modbus Word and Modbus Double Word register types. This defaults to false (unsigned) but can be set to true. **Signed:** Signed is used for Modbus Word and Modbus Double Word register types. This defaults to false (unsigned) but can be set to true.
Line 72: Line 98:
 **SwapStyle:** see description for Modbus Double Word above. **SwapStyle:** see description for Modbus Double Word above.
  
-====Parameters specific to Modbus String and Modbus String Array ====+====Parameters specific to Modbus String ==== 
 + 
 +These are also used in the Modbus String Array
  
 **Length:** The length of the string (must be multiple of 2) **Length:** The length of the string (must be multiple of 2)
Line 94: Line 122:
 </code> </code>
  
 +** //Advice on defining arrays in the spreadsheet// **
  
-===Parameters specific to Modbus String Array=== +Since arrays add extra columns to the spreadsheet not used by regular modbus register types such as Word, Floats, and Double Words, it is recommended that you make a separate  spreadsheet with a devices sheet (tab) to set up just arrays or if not too many arrays are used in your project you can add these manually to the project. The purpose of this recommendation is to keep the regular register rows cleaner without the extra sparely populated parameters only used for arrays. 
- +=====EtherNet/IP (Allen Bradley,Omron CJ EtherNet/IP for NJ CPU)=====
- +
-====EtherNet/IP (Allen Bradley,Omron CJ EtherNet/IP for NJ CPU)====+
  
 see also: [[ethernetip_plc_addressing_for_all_products|EtherNet/IP Addressing]] see also: [[ethernetip_plc_addressing_for_all_products|EtherNet/IP Addressing]]
Line 141: Line 168:
 [[https://www.ergotech.com/files/examples/spreadsheets/EtherNetIPExample.xlsx|Example EtherNet/IP Devices Spreadsheet]] [[https://www.ergotech.com/files/examples/spreadsheets/EtherNetIPExample.xlsx|Example EtherNet/IP Devices Spreadsheet]]
  
-====Melsec (Mitsubishi Q)====+=====Melsec (Mitsubishi Q)=====
  
 Spreadsheet header example (order of column headers does not matter) Spreadsheet header example (order of column headers does not matter)
  • importing_device_servers_with_a_spreadsheet.1675291531.txt.gz
  • Last modified: 2023/02/01 16:45
  • by wikiadmin