西门子 S7-1200PLC编程 数组的使用方法
关注“ 技成微课堂 ”,一起涨知识~
私信回复:64,领64本西门子电子书!
使用数组数据类型注意事项
ARRAY类型是由数目固定且数据类型相同的元素组成的数据结构。ARRAY类型的定义和使用需要注意以下几点:
ARRAY类型可以在DB、OB/FC/FB接口区、PLC数据类型处定义;无法在PLC变量表中定义。数组定义:Array[维度1下限..维度1上限,维度2下限..维度2上限,...]of <数据类型>,最多可包含 6 个维度;数组元素的数据类型包括:除数组类型、Variant类型以外的所有类型;数组下标的数据类型为整数,下限值必须小于或等于上限值,上下限的限值在S7-1200 V3.0及其以前为Int范围(-32768~+32767),在S7-1200 V4.0及其以后前为DInt范围(-2147483648 ~+21474836487),可以使用局部常量或全局常量定义上下限值,数组的元素个数受DB块剩余空间大小以及单个元素大小的限制;从S7-1200 V2.0开始,下标可以不仅仅是常数、常量,也可以是变量,还可以是混合使用(多维数组),如果编程语言是SCL的话,下标还可以是表达式。使用数组的变量下标,可以在程序中很容易地实现间接寻址。注意,下标变量必须是符号名,不能是DB1.DBW0这种没有对应符号名的绝对地址。从S7-1200 V4.2开始,FC的Input/Output/InOut以及FB的InOut可以定义形如Array[*]这种变长数组,要求必须是优化FC/FB块,在调用FC/FB的实参中可以填写任意数据类型相同的数组变量;当然,也可以多维变长的数组,例如Array[*,*]of Int。数组可以使用单个数组元素例如"DB1".Static_1[1],也可以使用整个数组例如"DB1".Static_1。多维数组可以降维使用,例如三维数组:3D[0..2,0..3,0..4]of Int是一个3×4×5大小的Int数组,3D[0]是一个4×5大小的二维Int数组,3D[0,1]是一个5个元素的一维Int数组,当然多维数组下标也可以换成变量,例如3D[Tag_1,1]这种;S7-1200 V4.2开始,多重背景支持数组形式,即Array of FB,这样可以在FB中使用循环指令更方便的编写程序。不支持Array[*] of FB。在TIA 博途 V10.5 SP2,S7-1200 V1.0的时候,曾经引入FieldRead 和 FieldWrite 指令,用于数组下标的变址寻址,这种方法在TIA 博途 V11之后可以由下标变量完全取代,并且更为简化,所以该指令也只是位于“移动操作>原有”中,用于早期版本向上移植时使用,它的使用方法参见FieldRead 和 FieldWrite 间接寻址。数组的基本使用方法
一. DB中创建,如图1所示:
图1 Array在DB中的创建
二. FC的InOut中创建,如图2所示:
图2 Array在FC形参中的创建
三. 数组作为实参,如图3所示:
图3 Array作为FC的实参
四. FC程序中使用数组元素,使用形参,如图4所示:
图4 FC程序中使用形参
五. FC程序中使用数组元素,下标为变址寻址,使用形参, 如实现以下功能,将0-7这8个数,送入数组下标为0-7的8个元素,如图5-7所示:
(1)FC形参设置,如图5所示:
图5 FC形参设置
(2)程序编制,如图6所示:
图6 程序详情
(3)SCL的版本,如图7所示:
图7 SCL版本的程序
六. 在程序中直接使用数组元素,如图8所示:
图8 程序中直接使用数组元素
七. 在程序中直接使用数组元素,下标为变址寻址, 如实现以下功能,将0-7这8个数,送入数组下标为0-7的8个元素,如图9-11所示:
(1)数据块定义,如图9所示:
图9 DB1的定义
(2)程序编制,如图10所示:
图10 程序详情
(3)SCL的版本,如图11所示:
图11 SCL版本程序
Array【*】使用实例
实现以下功能:使用FC的Input定义数组Array[*] of Int,求变长数组元素的总和,可以按照以下步骤来完成。
一. 使用Array[*] ,必须使用如图12所示的指令,计算数组元素的上下限,从而得出元素个数:
图12 指令位置
二. 定义变量,如图13所示。赋初始值,计算上下限,如图14所示:
图13 定义形参
三、计算上下限程序,如图14所示:
(1)输入Array[*]类型的变量
(2)所求上下限的维数
(3)该维数下的下限/上限,DINT类型
图14 计算上下限
四. 求和程序,如图15所示:
图15 求和的程序
五. SCL的版本,如图16所示:
图16 SCL版本程序
六. OB1中调用实参为不同数组元素个数的数组,如图17所示:
图17 OB1调用程序
Array of FB的使用实例
实现以下功能:FB3多次调用FB4,在FB3内部循环调用,减少程序量。FB4的两个Input:Start,Stop,一个InOut:Run,建立Array[0..7] of FB4。同时建立变量 Array[0..7] of Struct,作为对应FB4的输入和输出,如图18所示:
图18 程序详情
版权声明:文章转自网络,版权归原作者所有。如有侵权,请联系我们删除!
私信回复:64,领64本西门子电子书!
Sumifs函数两种数组计算新思路,轻松解决多条件求和问题
我们都知道Sumifs函数是一个多条件的求和函数,然而可能许多人知道的也就仅仅是多条件求和。今天我们就来学习一下Sumifs函数两种新的计算方法,如何搭配数组进行综合运算。
案例一:计算销售一部性别为男性的一月份销售额
函数公式:
=SUMIFS(E2:E7,C2:C7,B11,D2:D7,C11)
函数解析:
这个解法为Sumifs函数最基础的用法。第一参数为需要计算的求和区域;第二参数为对应的条件区域一,第三参数为符合要求的条件值一;第四参数为条件区域二,第五参数为符合要求的条件值2,依次类推以达到多个条件计算。
下面我们来看两种不一样的数值求和方式:
数值求和一:计算女性人数中,部门为一部和三部的1月销售总和
函数公式:
=SUM(SUMIFS(E2:E7,D2:D7,B11,C2:C7,{"一部","三部"}))
函数解析:
1、在这里我们将sumifs函数里面的第五个参数条件值,用{}数组的方式进行统计,这样就可以将一部和三部两个条件的值计算出来;但是这样计算只能将符合条件的值算出来,不能最终的进行求和。结果如下图所示:
我们选择sumifs函数按F9进行解析,可以将一部和三部符合条件的值算出来;
2、sumifs数组方式计算出数据后,最后我们用sum求和函数再进行一次求和,这样即最终的进行求和计算。
数组求和二:计算一部和二部A和C产品一月销售总和
函数公式:
=SUM(SUMIFS(D3:D10,B3:B10,{"一部";"二部"},C3:C10,{"A","C"}))
函数解析:
1、这里的数组运用方法与方法一是一样的,都是将多个条件值用{}数组符号进行连接起来,最后用sum函数进行求和;
2、{"一部";"二部"}这里我们中间用的是分号“;”,{"A","C"}这里我们中间用的是逗号“,”。这就是这两个数组不一样的地方。区别在于数组自身的计算逻辑有关:
2.1 如果两个都用逗号,这样数组会一一对应的进行计算,就是一部A,二部C;
2.2 如果前面分号后面逗号代表的是,一部A和C,二部A和C这种一对多的关系。
现在你学会如何使用Sumifs函数进行多条件数组求和了吗?
相关问答
c语言如何使数组全部相加?
C语言中,如果想要实现数组全部相加,需要编写一个循环,再实现累加,具体做法是,首先定义一个整型变量sum,并赋初值为0,然后使用一个for循环,从下标0到n-1(...C...
C语言数组如何进行元素求和?-林儿响叮当的回答-懂得
intmain(){intn;intval;int*a;intsun=0,i;printf("请输入数组的长度:");scanf("%d&q...
VBA数组如何求和与计数?
答:Sum函数可以在工作表中求,同样也可以对VBA数组求和,如:Subt2()arr=Array(1,35,4,13)MsgBoxApplication.Sum(arr)'对...
labview移位寄存器数组求和是什么?
在LabVIEW中,移位寄存器是一种用于移位操作的数据结构,可以用于存储和操作二进制数据。移位寄存器数组是一组移位寄存器的集合。求和的过程是将移位寄存器数组...
vlookup可以多数据求和吗?
可以如果你想使用VLOOKUP函数汇总多个表数据并求和,可以按照以下步骤进行操作:1.首先,在Excel中打开包含需要汇总的数据的所有表格。2.在需要汇总数据的...
WPS数组绝对值求和公式?
方法一:1、打开excel表格,在A1与B1单元格输入数值。2、在C1单元格输入公式:=A1+B1,点击回车即可生成数据。方法二:1、选中需要求和的单元格,将生成结果...
如何让三行数据求和成一行?
将多行数据合并为一行并求和,可以使用以下步骤:首先,将每行数据按照一定的规则进行分割,例如使用逗号或制表符作为分隔符。将分割后的数据存储到一个列表或...
博途如何将数组转换成数值?
博途可以使用numpy中的array()函数将数组转换成数值。numpy是Python中用于科学计算的一个重要库,它提供了一个数组对象——ndarray,其具有快速、高效、灵活...
PHP取数组中几个数值求和等于指定值的算法?
看不懂你的问题。。$a=array(12,25,45,78,3);$sum=$a[0]+$[1];//sum=37看不懂你的问题。。$a=array(12,25,45,78,3);$sum=$...
vba按多条件求和的思路是什么样?
1、将多个条件合并,用&链接在一起,作为一个key放进字典多条件变单条件2、然后套路就是:字典标记行号,单条件多列求和。代码:Sub多表求和()Dimarr,...