西门子供应SITOP电源经销商
PLC是什么意思?相信很多人处于大概知道是什么,但是又无法准确说出的阶段,作为专注于为企业提供数据采集和设备控制解决方案的众诚工业,今天和大家探讨一下。
而众诚工业还能根据用户需求,设计PLC控制程序,为客户提供PLC编程和上位机软件的定制化开发技术服务,满足用户的多种需求,比如,自主研发的洁净空调智能控制系统和通风排风智能控制系统就配置PLC,不仅具有报警和定时控制功能,还兼具可扩展性和兼容性,系统能被第三方系统集成。
以上PLC的基本介绍,相信大家对PLC也有一个初步的了解。PLC的型号、品牌不同,对应着其结构形式、性能、编程方式等等都有所差异,价格也各不相同,在挑选时候,建议先要明确自己的应用需求,比如具体的应用场景,希望实现的运动和控制功能,已经特殊的控制要求,这些将决定了PLC的选型和搭配组合。
简单地说,PLC就是一种小型的计算机,和我们常用的计算机不同的是,PLC是设备之间通过数字信号进行互动,而我们常用的计算机,是人和计算机的互动。
控制是PLC的核心功能,其控制类型主要分为以下几种1、开关量的开环控制。这是PLC*基本的控制功能,它能凭借其强大的逻辑运算能力,取代传统继电接触器的控制系统;
2、数据采集与监控。这是PLC非常必要的功能,否则它将无法完成现场控制;
3、数字量智能控制。PLC具有实现接收和输出高速脉冲的功能,近年来先进的PLC还开发了数字控制模块和新型运动单元模块,让工程师更加轻松地通过PLC实现数字量控制;
4、PLC能通过模拟量采集和调节温度、压力、速度等参数。
正因为PLC功能强大,且具有设计方便、重量体积小、能耗低、改造工作量小、通用性强、维护方便等易学易用的特点,深受工程师的欢迎,因此应用非常广泛,钢铁、石油、化工、纺织、交通、机械制造等等行业都能看到它的身影。
DataLogCreate 指令的 HEADER 参数 HEADER 参数指向 CSV文件中编码的数据矩阵的第一行的列标题名称。HEADER 数据必须位 于 DB 或 M 存储器,且字符必须遵守标准 CSV格式规则,各列名称用逗号分隔。数据类型 可以是字符串、字节数组或字符数组。字符/字节数组的大小可以增加,其中字符串被限制 为*多255 个字节。HEADER 参数是可选参数。如果未分配 HEADER 参数,则不会在数据日 志文件中创建标题行。 9.9.2.2控制数据日志的程序指令 DataLogCreate(创建数据日志) 表格 9-201 DataLogCreate 指令 LAD/FBDSCL 说明 "DataLogCreate_DB"( req:=_bool_in_, records:=_udint_in_,format:=_uint_in_, timestamp:=_uint_in_, done=>_bool_out_,busy=>_bool_out_, error=>_bool_out_, status=>_word_out_,name:=_string_inout_, ID:=_dword_inout_, header:=_variant_inout_,data:=_variant_inout_); 创建和初始化数据日志文件。CPU 在 \DataLogs 文件夹中使用 NAME参数中的名 称创建文件,并且以隐式打开以便执行写操 作。在程序中,可使用 Data log 指令将运行 系统过程数据存入 CPU的闪存或存储卡中。 STEP 7 会在插入指令时自动创建关联的背景 数据块。 1 在 SCL示例中,“DataLogCreate_DB”是背景数据块的名称。 表格 9-202 参数的数据类型 参数和类型 数据类型 说明 REQIN Bool 通过由低到高的(上升沿)信号启动操作。(默认 值:False) RECORDS IN UDint覆盖*旧条目前循环数据日志可存储的*大数据记 录数: 不包括标题记录。PLC 装载存储器的可用空间必须足够大,以确保成功创建数据日志数据日志格式: • 0 - 内部格式(不支持) • 1 - 逗号分隔值“csv-eng”(默认值)TIMESTAMP IN UInt 数据时间戳格式:日期和时间字段的列标题是可选 的。时间戳可使用系统时间(世界协调时间 - UTC)或本地时间。 • 0 - 无时间戳 • 1 - 系统时间 mm/dd/yyyy,hh:mm:ss • 2 - 本地时间mm/dd/yyyy,hh:mm:ss • 3 - 系统时间 mm/dd/yyyy,hh:mm:ss • 4 - 本地时间yyyy-mm-dd,hh:mm:ss • 5 - 系统时间 yyyy-mm-dd,hh:mm:ss NAME IN Variant数据日志名称:用户可在此提供名称。此变量仅支 持 String 数据类型,且必须位于 DB 或本地存储器 中。(默认值:' ')该字符串引用为数据日志文件名。使用 ASCII 字符 集中的字符,除了字符 \ / : * ? " < > |及空格字符。 ID In/Out DWord 数据日志数字标识符:存储该生成值以便与其它数 据日志指令配合使用。ID 参数仅用作DataLogCreate 指令的输出。(默认值:0) 该参数不支持符号名称访问。 HEADER In/Out Variant 指向CSV 文件中编码的数据矩阵的第一行的数据日 志列标题名称。(默认值:null)。 HEADER 数据必须位于 DB 或 M 存储器。字符必须遵守标准 CSV 格式规则,各列名称用逗号 分隔。数据类型可以是字符串、字节数组或字符数组。字符/字节数组的大小可以增加,其中字符串被 限制为*多 255 个字节。说明 DATA In/Out Variant指向记录数据结构、用户自定义类型 (UDT) 或数 组。记录数据必须位于 DB 或 M 存储器。 DATA参数指定数据日志记录的各个数据元素(列) 及其数据类型。DataLogCreate 指令将结构数据类型限制为单嵌套级。在这种情况下,字符串数组不 视为单嵌套级。DataLogCreate 指令当前不会返回错误。该指令仅处理字符串数组中的第一个字符 串。所声明数据元素的个数应与标题参数中指定的 列数相对应。可以分配的*大数据元素个数为253 (带时间戳)或 255(不带时间戳)。此限制可保证 记录始终处于 Excel 工作表的 256 列限制范围内。 DONEOUT Bool 上一请求已完成且没有出错后,DONE 位将保持为 TRUE 一个扫描周期时间。(默认值:False) BUSYOUT Bool • 0 - 无操作正在进行 • 1 - 操作正在进行 ERROR OUT Bool上一请求因错误而终止后,ERROR 位将保持为 TRUE 一个扫描周期时间。STATUS 参数中的错误代 码值仅在 ERROR =TRUE 的一个扫描周期内有效。 STATUS OUT Word 执行条件代码(默认值:0) CPU 根据 RECORDS 和DATA 参数按预定的固定大小创建数据日志文件并按循环日志文件形 式组织数据记录。当指令返回 DONE = TRUE时,DataLogCreate 指令为整个数据日志分配持 久 CPU 内存。由于存在文件系统管理和相关的值,CPU中所需的内存大于文件的大小。数 据日志的持久性内存保持分配状态,直至 CPU 以下列方式之一取消分配内存: • 用户程序调用DataLogDelete 指令 • Web 服务器用户从 Web 服务器中删除数据日志 • SIMATIC AutomationTool 用户从 SIMATIC Automation Tool 中删除数据日志通过其它方式(例如使用读卡器)删除数据日志文件,不会为数据日志取消分配 CPU 持久 内存。 DataLogWrite指令不断将新记录添加到数据日志文件中,直到已存储 RECORDS 参数指定的 *大记录数为止。写入的下一条记录将覆盖*早的记录。另一DataLogWrite 操作将覆盖下 一条*早的数据记录,依此类推。 数据日志仅占用装载存储器。• 组合起来的所有数据日志的大小受装载存储器可用资源的限制。仅可同时打开八个数据 日志。可通过文件浏览器 (页 900)标准 Web页面管理这些数据日志。请参见此标准 Web 页面的描述,获取可同时维护的数据日志数量的相关指南。 • RECORDS参数的*大可能数值是 UDint 数的限值 (4,294,967,295)。RECORD 参数的实际限值取决于单个记录的大小、其它数据日志的大小及装载存储器的可用资源。此外,Excel 对 Excel 工作表中允许的行数也有一定限制。说明 在开始数据日志写入操作前,必须完成执行数据日志创建 • DataLogCreate 和 DataLogNewFile日志文件创建操作可能持续多个程序扫描周期。创建日志 文件所需的实际时间取决于记录结构和记录数。程序逻辑必须监视并捕捉到 DONE位转换为 TRUE 状态后,才表示日志文件创建完成。如果用户程序在数据日志创建操作完成之前执行 DataLogWrite指令,写操作将无法按要求写入新的数据日志记录。 • 在非常快的程序扫描运行的特定情况下,数据日志创建过程可能需要较长时间。如果这种长时间的创建过程过慢,应确保已激活“启用循环 OB 的*小循环时间”复选框,并将*小循 环时间设置为 1 ms或更大的值。更多信息,请参见组态循环时间和通信负载 (页 87)。 说明 DataLogNewFile指令可复制现有数据日志的记录结构 如果要防止覆盖任何数据记录,则可在当前数据日志已存储*大记录数后,使用 DataLogNewFile指令基于当前数据日志创建新数据日志。新数据记录将存储到新数据日志 文件中。旧数据日志文件及记录数据仍保存在闪存中。 表格 9-203ERROR 和 STATUS 的值 ERROR STATUS (W#16#....) 说明 0 0000 无错误 0 7000 无REQ 沿时调用:BUSY = 0,DONE = 0 0 7001 有 REQ 沿时首次调用(工作):BUSY = 1,DONE =0 0 7002 第 N 次调用(工作):BUSY = 1,DONE = 0 1 8070所有内部实例存储器都在使用。 称参数不是字符串引用。 1 8093已存在具有该名称的数据记录。使用其它名称,确保现有数据日志的 .csv 文 件未打开,然后使用文件浏览器 (页 900) Web服务器页面删除现有数据日 志。 1 8097 请求的文件长度超出文件系统*大值。 1 80B2 不在源 ID 范围内注:删除一些现有数据日志或减少数据记录结构中列的数量可避免此错误。 1 80B3 可用装载存储器空间不足。 1 80B4MC(存储卡)为写保护。 1 80C0 归档文件已锁定 1 80C1 打开的文件过多:*多只允许同时打开 8 个数据日志文件。 18253 记录计数无效 1 8353 格式选择无效 1 8453 时间戳选择无效 1 8B24 HEADER区域分配无效:例如,指向本地存储器 1 8B51 HEADER 参数数据类型无效 1 8B52 HEADER 参数数据元素过多 18C24 DATA 区域分配无效:例如,指向本地存储器说明 "DataLogOpen_DB"( req:=_bool_in_,mode:=_uint_in_, done=>_bool_out_, busy=>_bool_out_,error=>_bool_out_, status=>_word_out_, name:=_string_inout_,ID:=_dword_inout_); 打开已有数据日志文件。必须先打开数据日志,才能向该日 志写入 (页508)新记录。可单独打开或关闭各个数据日志。 *多可同时打开八个数据日志。 STEP 7 会在插入指令时自动创建关联的背景数据块。2 在 SCL 示例中,“DataLogOpen_DB”是背景 DB 的名称。 表格 9-205 参数的数据类型 参数和类型 数据类型说明 REQ IN Bool 通过由低到高的(上升沿)信号启动操作。(默认值:False) MODE IN UInt 工作模式: •0 - 附加到现有数据(默认值) • 1 - 清除所有现有记录 NAME IN Variant 现有数据日志的名称:此变量仅支持String 数据类型,且只 可位于本地、DB 或 M 存储器。(默认值:' ') ID In/Out DWord数据日志的数字标识符。(默认值:0) 注:该参数不支持符号名称访问。 DONE OUT Bool 上一请求已完成且没有出错后,DONE位将保持为 TRUE 一 个扫描周期时间。(默认值:False) BUSY OUT Bool • 0 - 无操作正在进行 • 1 -操作正在进行 ERROR OUT Bool 上一请求因错误而终止后,ERROR 位将保持为 TRUE 一个扫 描周期时间。STATUS参数中的错误代码值仅在 ERROR = TRUE 的一个扫描周期内有效。 STATUS OUT Word 执行条件代码(默认值:0)可提供已有数据日志的 NAME 或 ID(ID 参数作为输入)。如果同时提供这两个参数,但有 效的 ID 与 NAME数据日志不对应,则使用 ID,而忽略 NAME NAME 必须是DataLogCreate 指令创建的数据日志的名称。如果只提供 NAME 且 NAME 指 定一个有效数据日志,将返回对应的ID(ID 参数作为输出)。 说明 数据日志文件的一般用法 • 执行 DataLogCreate 和 DataLogNewFile操作后会自动打开数据日志文件。 • PLC 从 RUN 切换到 STOP 或 PLC 循环上电后,数据日志文件会自动关闭。 •必须打开了数据日志文件,才能执行新的 DataLogWrite 操作。 •*多可同时打开八个数据日志文件。可存在八个以上数据日志文件,但必须关闭一些数据日 志文件,使打开的文件数不超过八个。 表格 9-206ERROR 和 STATUS 的值 ERROR STATUS (W#16#) 说明 0 0000 无错误 0 0002警告:数据日志文件已通过该应用程序打开 0 7000 无 REQ 沿时调用:BUSY = 0,DONE = 0 0 7001 有REQ 沿时首次调用(工作):BUSY = 1,DONE = 0 0 7002 第 N 次调用(工作):BUSY = 1,DONE =0 1 8070 所有内部实例存储器都在使用。 1 8090 数据日志定义与现有数据日志文件不一致。 1 8091名称参数不是字符串引用。 1 8092 数据日志不存在。 1 80C0 数据日志文件被锁定。 1 80C1打开的文件过多:*多只允许同时打开 8 个数据日志文件说明 "DataLogWrite_DB"( req:=_bool_in_,done=>_bool_out_, busy=>_bool_out_, error=>_bool_out_,status=>_word_out_, ID:=_dword_inout_); 将数据记录写入指定的数据日志。必须先打开 (页506)已有目标 数据日志,才能使用 DataLogWrite 指令对其执行写入操作。 STEP 7会在插入指令时自动创建关联的背景数据块。 2 在 SCL 示例中,“DataLogWrite_DB”是背景 DB 的名称。 表格9-208 参数的数据类型 参数和类型 数据类型 说明 REQ IN Bool通过由低到高的(上升沿)信号启动操作。(默认值:False) ID In/Out DWord 数据日志数字标识符。仅用作DataLogWrite 指令的输入。(默 认值:0) 注:该参数不支持符号名称访问。 DONE OUT Bool上一请求已完成且没有出错后,DONE 位将保持为 TRUE 一个扫 描周期时间。 BUSY OUT Bool • 0 -无操作正在进行 • 1 - 操作正在进行 ERROR OUT Bool 上一请求因错误而终止后,ERROR 位将保持为 TRUE一个扫描周 期时间。STATUS 参数中的错误代码值仅在 ERROR = TRUE 的一个 扫描周期内有效。 STATUS OUTWord 执行条件代码(默认值:0) DataLogCreate 指令的 DATA参数定义记录缓冲区的存储器地址和数据结构。控制程序必须 使用当前运行系统过程值装载记录缓冲区,然后执行 DataLogWrite指令将新记录数据从缓 冲区移动到数据日志。 ID 参数用于标识数据日志和数据记录组态。DataLogCreate 指令将生成 ID编号 如果循环数据日志文件中存在空记录,则 DataLogWrite指令将写入下一条可用的空记录。如 果所有记录均不为空,则 DataLogWrite 指令将覆盖*早的记录。 注意在开始数据日志写入操作前,必须完成数据日志创建操作 DataLogCreate 和 DataLogNewFile日志文件创建操作可能持续多个程序扫描周期。创建日 志文件所需的实际时间取决于记录结构和记录数。程序逻辑必须监视并捕捉到 DONE 位转换为 TRUE 状态后,才表示日志文件创建完成。如果在数据日志创建操作完成之前执行 DataLogWrite指令,写操作将无法写入新的数据日志记录。 说明 数据日志对 CPU 存储器的影响 每次数据日志写入至少占用 2 KB的存储空间。如果程序频繁写入少量数据,则每次写入至 少占用 2 KB 的存储空间。采用某个数据块 (DB)存放这些小数据量数据项,然后,以较小频 次将该数据块写入数据变量不失为一种更好的实现方法。如果程序需要非常频繁地写大量数据变量条目,则应该考虑采用可以更换的 SD 存储卡。 注意 CPU 电源故障时数据日志数据丢失的可能性如果未完成 DataLogWrite 操作时发生电源故障,则当前正向数据日志传送的数据记录可能 会丢失。 表格 9-209 ERROR和 STATUS 的值 ERROR STATUS (W#16#) 说明 0 0000 无错误 0 0001表明数据日志已满:创建的各数据日志只能存储指定的*大记录数。如 果写入*后一条记录后达到*大记录数,则下一写操作将覆盖*早的记 录。0 7000 无 REQ 沿时调用:BUSY = 0,DONE = 0 0 7001 有 REQ 沿时首次调用(工作):BUSY =1,DONE = 0 0 7002 第 N 次调用(工作):BUSY = 1,DONE = 0 1 8070所有内部实例存储器都在使用。 1 8092 数据日志不存在。 1 80B0 数据日志文件未打开(仅针对显式打开模式)说明"DataLogClear_DB"( REQ:=_bool_in_, DONE=>_bool_out_,BUSY=>_bool_out_, ERROR=>_bool_out_, STATUS=>_word_out_,ID:=_dword_inout_); 指令“DataLogClear”可删除现有数据记录中的 所有数据记录。该指令不会删除 CSV文件的可 选标题(请参见指令“DataLogCreate (页 501)”的 HEADER 参数说明)。 可以使用参数 ID选择要删除数据记录的数据 记录。 “DataLogClear_DB”是背景数据块的名称。 要求 删除数据记录前,必须打开数据记录。使用DataLogOpen (页 506) 指令打开数据日志。 参数 下表列出了“DataLogClear”指令的参数: 参数 声明数据类型 存储区 说明 REQ Input BOOL I、Q、M、L、D、 T、C 或常量 (对于 S7-1500,T 和 C 只能在LAD 和 FBD 中使用) 在上升沿执行指令。 ID InOut DWORD I、Q、M、D、L 数字数据日志标识符 DONEOutput BOOL I、Q、M、D、L 指令已成功执行。 BUSY Output BOOL I、Q、M、D、L指令的执行尚未完成存储区 说明 ERROR Output BOOL I、Q、M、D、L • 0:无错误。 •1:指令执行期间出现错误。 详细信息将在 STATUS 参数中输出。 STATUS Output WORD I、Q、M、D、L状态参数 该参数设置仅维持一次调用所持续的时 间。因此,要显示其状态,应将 STATUS 参数复制到可用数据区域。有关有效数据类型的更多信息,请参见“数据类型 (页 103)”。 参数 STATUS 错误代码* (W#16#...) 说明 0000无错误。 7000 未激活任何作业处理。 7001 启动作业处理。参数 BUSY = 1,DONE = 0 7002 中间调用(与REQ 无关):已激活指令;BUSY 的值为“1”。 8080 使用 ID参数选择的数据记录文件无法使用“DataLogClear”指令处理。 8092 数据日志不存在。 80A2 文件系统返回写入错误。80B0 数据记录未打开。 80B4 存储卡受到写保护。 *在程序编辑器中,错误代码可显示为整数或十六进制值。有关切换显示格式的信息,请参见“另请参见”