网站首页 > 知识剖析 正文
PLC经常用到的时间格式TIME; TIME_OF_DAY; DAY ; DAY_AND_TIME; 很多人只会赋值,不明白存储机制,所以数据之间相互转换和不同设备之间需要传递时间参数,会遇到搞不定的问题,我就遇到了这个问题,我的倍福PLC需要给西门子PLC发送DAY_AND_TIME日期数据,之间只能通过byte传输,一时间没了办法。下面就由我来一步一步解决这个问题。
第一步:配置确定
倍福plc和西门子Profibus模块通讯,数据交换。配置里只有BYTE选项,如下图,选了一个64BYTE的输入输出接口,只能通过BYTE传输数据,再转换成需要的日期数据。
第二步:数据技术分析
我们在项目中需要传输4个时间和日期的数据,TIME; TIME_OF_DAY; DAY ; DAY_AND_TIME;下面一一给列出分析:
TIME类型是时间数据,最少单位为1ms。格式为:T# xx d xx h xx m xx s xx ms。其中:T表示时间常数起始,#表示其后为立即数,d表示天,h表示小时,m表示分,s表示秒,ms表示毫秒。如T#1d2h3m4s500ms,表示1天2小时3分钟4秒500毫秒。
写个模拟程序如下图:把时间存储到DWORD里看每个字节是怎么显示的。如下图程序,time类型无法直接赋值给DWORD,所以需要指令TIME_TO_DWORD,进行转换。
让程序运行起来,给tTime赋值1分钟,如下图,DWORD数据结构dwTime里存储的32位16进制数为00 00 EA 60; 转换为10进制数是60000,而我输入的1分钟即为60000毫秒,所以dwTime里存储的为tTIME最小单位表示的数字。 项目里把32位16进制数00 00 EA 60发给西门子模块就可以,西门子再把它转换为时间就可以了。
总结一下1分钟时间的数据存储结构如下图:
TIME_OF_DAY类型是一天中的时间,时间起始时间12:00AM ,最少单位为1ms。TIME_OF_DAY类型数据格式为:TOD#HH:mm:ss。其中:TOD表示TIME_OF_DAY常数起始,#表示其后为立即数,HH表示小时,mm表示分,ss表示秒。如TOD#13:30:30,表示13点30分30秒。
写个模拟程序如下图:把时间存储到DWORD里看每个字节是怎么显示的。如下图程序,time类型无法直接赋值给DWORD,所以需要指令TOD_TO_DWORD,进行转换。
让程序运行起来,给todTime赋值1:00,如下图,DWORD数据结构dwTime里存储的32位16进制数为00 36 EE 80;转换为10进制数是3600000,而我输入的1:00比起始时间12:00大1小时,也就是3600000ms,所以dwTime里存储的为tTIME最小单位表示的数字。项目里把32位16进制数00 36 EE 80发给西门子模块就可以,西门子再把它转换为时间就可以了。
总结一下1:00的数据存储结构如下图:
DATE类型是日期,最小单位为秒,起始时间1970年1月1日。数据类型的格式为:DATE#YY-MM-DD。其中:DATE表示DATE常数起始,#表示其后为立即数,YY表示年,MM表示月,DD表示日。如DATE#1970-1-2,表示1970年1月2日。
写个模拟程序如下图:把时间存储到DWORD里看每个字节是怎么显示的。如下图程序,time类型无法直接赋值给DWORD,所以需要指令DATE_TO_DWORD,进行转换。
让程序运行起来,给dTime赋值1970-01-02,如下图,DWORD数据结构dwTime里存储的32位16进制数为00 01 51 80;转换为10进制数是86400,而我输入的1970-01-02比起始时间1970-01-01大1天,最小单位为s,也就是86400s,所以dwTime里存储的为dTIME最小单位表示的数字。项目里把32位16进制数00 01 51 80发给西门子模块就可以,西门子再把它转换为时间就可以了。
总结一下1970-01-02的数据存储结构如下图:
DATE_AND_TIME类型是日期和时间组合的数据,最小单位为秒,起始时间1970年1月1日12:00AM。数据格式为:DT#YY-MM-DD-HH:mm:ss。其中:DT表示DATE_AND_TIME常数起始,#表示其后为立即数,YY表示年,MM表示月,DD表示日,HH表示小时,mm表示分,ss表示秒。如1970-1-2-13:30:30,表示1970年1月2日13点30分30秒。
写个模拟程序如下图:把时间存储到DWORD里看每个字节是怎么显示的。如下图程序,time类型无法直接赋值给DWORD,所以需要指令DT_TO_DWORD,进行转换。
让程序运行起来,给datTime赋值1970-01-02-00:01,如下图,DWORD数据结构dwTime里存储的32位16进制数为00 01 51 BC;转换为10进制数是86460,而我输入的1970-01-02-00:01比起始时间1970-01-01大1天1分钟,最小单位为s,也就是86460s,所以dwTime里存储的为dTIME最小单位表示的数字。项目里把32位16进制数00 01 51 BC发给西门子模块就可以,西门子再把它转换为时间就可以了。
总结一下1970-01-02-00:01的数据存储结构如下图:
第三步:西门子侧技术
西门子的数据结构和Codesys平台有些不同,比如DATE_AND_TIME数据结构是下图这样的,转换时候还是要注意下,这里不多说西门子的,以后单独写西门子的数据结构。
最后,时间和日期的数据结构,到此就研究差不多了,不同型号的设备都大同小异,原理都一样,上面西门子的数据结构不同,原理也是一样的,只不过分了不同的字节存储不同的数据。有问题可以评论区问我。
猜你喜欢
- 2024-12-14 FANUC系统时间如何来设定?教你用PMC窗口功能读取系统时间、日期
- 2024-12-14 Excel时间日期函数——DAYS360函数详解
- 2024-12-14 日期函数-Excel日期格式常用转换方法大全
- 2024-12-14 Excel表格技巧—如何快速转换日期格式
- 2024-12-14 PowerBI_Calendar函数生成日期表
- 2024-12-14 Excel – 根据月份换算出季度,几种经典公式
- 2024-12-14 iPhone12和iPhone12Pro听筒无声音召回计划和序列号生产日期查询
- 2024-12-14 02-PMC生产计划工具箱-开工日期与完工日期二维排程
- 2024-12-14 Excel时间日期函数——DATEDIF函数详解
- 2024-12-14 EXCEL日期格式TETX函数合并,日期时间日期文本连接显示,赶紧GET
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)