• {{item.name}}
SIMATIC S7-1200系列 {{item.name}}
{{item2.name}}
更多

配方指令

star star star star star
0 分
  • 使用操作
发布时间:2024年08月08日
  • 0
  • 403
配方指令

配方相关指令介绍

配方功能主要使用4个指令,READ_DBL和WRIT_DBL用于对配方数据块的读写,RecipeExport和RecipeImport用于配方数据块和CSV文件之间的转化,下面分别介绍这4个指令的使用。

READ_DBL

指令的目的是将数据块变量中的装载存储器部分的值,传送到数据块变量中的工作存储器部分中。 如图1所示。

通常用于配方中,将仅存储在装载存储器的配方数据读取到活动配方。

图1 READ_DBL与WRIT_DBL原理

表1 参数列表

参数声明数据类型说明
REQInputBoolREQ = 1:读取请求,通常建议沿触发
SRCBLKInputVariant待读取的数据块变量
RET_VALReturnInt状态、错误信息
BUSYOutputBoolBUSY = 1:读取中
DSTBLKOutputVariant待写入的数据块变量,和SRCBLK数据类型一致,优化属性一致

以配方功能快速入门的例子程序为例

图2 READ_DBL应用

如图2所示,SRCBLK的实参为“DB1_蛋糕配方”.Static_1["DB3_操作".Index],其中DB1_蛋糕配方”.Static_1是UDT类型(蛋糕配方)的数组,而带上后面的["DB3_操作".Index],就变成了数组中的一个元素,也就是说“DB1_蛋糕配方”.Static_1["DB3_操作".Index]是一个UDT类型(蛋糕配方)。

而DSTBLK的实参是“DB2_活动配方”,“DB2_活动配方”是基于UDT类型(蛋糕配方)建立的DB,也就是说“DB2_活动配方”可以看做UDT类型。

SRCBLK和DSTBLK的实参都是UDT类型,可以使用READ_DBL指令,是将“DB1_蛋糕配方”.Static_1["DB3_操作".Index]也就是配方中的一组读取到活动配方中。

WRIT_DBL

指令的目的是将数据块变量中的工作存储器部分写入到数据块变量中的装载存储器部分。 如图1所示。

通常用于配方中,将活动配方写入到仅存储在装载存储器的配方数据。

表2 参数列表

参数声明数据类型说明
REQInputBoolREQ = 1:写入请求,通常建议沿触发
SRCBLKInputVariant待读取的数据块变量
RET_VALReturnInt状态、错误信息
BUSYOutputBoolBUSY = 1:读取中
DSTBLKOutputVariant待写入的数据块变量,和SRCBLK数据类型一致,优化属性一致

以配方功能快速入门的例子程序为例

图3 WRIT_DBL应用

如图3所示,SRCBLK的实参是“DB2_活动配方”,“DB2_活动配方”是基于UDT类型(蛋糕配方)建立的DB,也就是说“DB2_活动配方”可以看做UDT类型。

而DSTBLK的实参为“DB1_蛋糕配方”.Static_1["DB3_操作".Index],其中“DB1_蛋糕配方”.Static_1是UDT类型(蛋糕配方)的数组,而带上后面的["DB3_操作".Index],就变成了数组中的一个元素,也就是说“DB1_蛋糕配方”.Static_1["DB3_操作".Index]是一个UDT类型(蛋糕配方)。

SRCBLK和DSTBLK的实参都是UDT类型,可以使用WRIT_DBL指令,是将活动配方写入到“DB1_蛋糕配方”.Static_1["DB3_操作".Index]也就是配方中的一组中。

RecipeExport

指令的目的是将仅存储在工作存储器中的配方数据(UDT数组)导出成为.csv文件,方便在电脑上的EXCEL或者ASCII编辑器编辑。

表3 参数列表

参数声明数据类型说明
REQInputBool沿触发:激活请求
RECIPE_DBInOutVariant待导出的配方数据块变量,通常是配方UDT的数组
DONEOutputBoolDONE= 1:导出完成,只维持一个扫描周期
BUSYOutputBoolBUSY = 1:导出中
ERROROutputBoolERROR= 1:导出错误,只维持一个扫描周期,错误代码参见STATUS
STATUSOutputWord状态或错误代码,错误代码只维持一个扫描周期

以配方功能快速入门的例子程序为例

图4 RecipeExport应用

“DB1_蛋糕配方”.Static_1是UDT类型(蛋糕配方)的数组,导出后生成DB1_蛋糕配方.csv文件。

RecipeImport

指令的目的是将在电脑上的EXCEL或者ASCII编辑器编辑过后的.csv文件导入成为仅存储在工作存储器中的配方数据(UDT数组)。

表4 参数列表

参数声明数据类型说明
REQInputBool沿触发:激活请求
RECIPE_DBInOutVariant导入后的配方数据块变量,通常是配方UDT的数组
DONEOutputBoolDONE= 1:导入完成,只维持一个扫描周期
BUSYOutputBoolBUSY = 1:导入中
ERROROutputBoolERROR= 1:导入错误,只维持一个扫描周期,错误代码参见STATUS
STATUSOutputWord状态或错误代码,错误代码只维持一个扫描周期

以配方功能快速入门的例子程序为例

图5 RecipeImport应用

需要将DB1_蛋糕配方.csv文件导入后,将“DB1_蛋糕配方”.Static_1这个UDT类型(蛋糕配方)的数组的值覆盖。


剩余80%未阅读,请登录查看大全章节内容

  • 评论
更多
  • 分享

    扫码分享

考证咨询点我

信息提示
很抱歉!您所访问的页面不存在,或网址发生了变化,请稍后再试。