1、自动生成需要的标记名
在intouch开发环境中,将向导库中/趋势/历史向导(HistData)放入窗口,这将自动生成若干标记名(如下)。
有关标记名以HDW开头,加上他们的DDE的Item命名。
标记名说明如下:
HDWDataDir 消息型历史数据文件的目录的路径名,可用函数赋值。
例如:HDWDataDir = HTGetLogDirectory();
HDWDBDir 消息型intouch标记名字典的目录的路径名,可用函数赋值。
例如:HDWDBDir = InfoInTouchAppDir();
HDWStratDate 消息型与$DataString 相同格式的数据采样开始日期。
例如:
HDWStartTime 消息型使用24小时时钟的HH:MM:SS 格式的数据采样开始时间
例如:09:45:33
HDWDuration 消息型数据时间长度(报表时间总长度)
可以用星期,天,时,分,秒,等来表示。
下面是有效的
字符:W 星期,D 天,H 小时;M 分,S 秒。
允许使用
小数值例如:表示500毫秒;若只需要一个样本,请将Duration
设为零。
HDWInterval 消息型采样间隔的时间长度
可以用星期,日,小时,分,秒来表示例如1W 表示一
星期。
允许使用小数值例如:.25d 来表示6小时。
有效字
符与HDWDuration相同;注意Duration 和Interval允许的最打
时间长度为6周,这适用于所有请求类型日,秒,等。
例如如
果使用日则最大值为42, 7天*6周=42天。
HDWTags 消息型历史数据的标记名列表(报表中需要的标记名)
以taga,tagb;tagz格式输入,此外采样日期或时间可以通过使用
内部系统标记$Date和$Time来请求。
HDWFileName 消息型规定生成的.CSV文件的路径和名称。
例如:E:\111\
HDWWriteFile 整形当设置为1时,HistData 会将请求数据写入由FileName项目
名指定的文件,当文件更新完成后WriteFile 会自动重置为0 Status 离散型显示最后一次操作的状态 1 表示成功,0 表示出错
Error 消息型包含上次错误说明的字符串,如Status 为1 则表示无,如Status
为0 则表示错误消息字符串。
例如:下面脚本生成一个日期由StartData1规定,但包含两个标记名PI-101;TI-101,日报表。
可以复制在脚本中,修改一下就可以形成所需的.CSV文件。
HDWStartDate=StartDate1;
HDWStartTime=”00:00:00”;
HDWDBDir=InfoIntouchAppDir();
HDWDataDir=HTGetLogDirectory();
HDWFilename=” E:\111\”;
HDWTags=”$Date,$Time, PI-101,TI-101”;
HDWInterval=”1H”;
HDWDuration=”1D”;
HDWWritefile=1;
例如:设计一个按钮,当按下按钮时,生成一个.CSV表格。
生成表格的起始日期,和起始时间可调,表格时间间隔也可调。
新建内存型标签,标签数据类型为消息型:startdate 消息型;starttime 消息型
其中:a,b,c,d,e,f 为需要在excel表格中体现的数据列。
报表生成。
HDWStartDate = startdate; HDWStartTime =starttime; HDWDBDir = InfoInTouchAppDir(); HDWDataDir = HTGetLogDirectory(); HDWFilename = "E:\111\"; HDWTags ="$Date, $Time, temp1,level1"; HDWInterval = "1s";
HDWDuration = Text(t,"#")+"h" ; HDWWriteFile=1;
StartApp "E:\111\";。