在WinCC中可以通过报警纪录来实现操作员纪录,这个需要WinCC的消息系统进行组态和配置。

利用消息系统进行实现上诉功能不但复杂而且时间久啦也不方便查询。那么有没有一种简单的方法来

实现操作员纪录呢?

  我们知道在Windows系统中可以通过批处理来实现很多功能,而且操作也比较简单,学习起来也

没有多大的难度。那么我们是否可以Windows的批处理功能来实现日志功能呢?

  

一、WinCC执行外部程序。

  在WinCC中通过

ProgramExecute("notepad.exe");

 函数可以执行外部程序。  其中函数的参数是外部程序的路径和可执行文件名。

二、cmd解释器的路径和直接启动cmd解释器传递参数

1、查看路径

我们可以通过命令行查看 cmd 解释器的路径。 默认cmd解释程序的路径为:%windir%\system32\cmd.exe

  图 利用命令行查看cmd解释的路径和可执行文件名

2、给cmd解释器传递参数

  在运行对话框中输入命令:

cmd /c start notepad.exe

  这个命令直接就可以启动记事本程序。

  图 利用cmd的方式启动记事本程序。

  这个命令需要解释一下:

cmd 是命令解释器可执行程序,后面的   /c start notepad.exe 是传递给cmd的参数, /c 表示后面的

字符串是一个命令行,是一条命令;  start 表示是要启动一个程序,  notepad.exe 是要启动的程序。

三、利用cmd解释器直接生成log文件

  在运行对话框输入:

cmd /c  echo "我是log测试行">>C:\Users\volcanol\Desktop\log.txt

  如下图所示:

  点击确定执行。在桌面生成一个文件 log.txt, 并且我们的内容也输入到了文件中,如下图所示:

  图 利用cmd解释器生成的log.txt 文件

三、WinCC脚本执行

  结合上面说的cmd解释器的执行和在WinCC中执行外部程序,我们就可以做成一个简易的操作记录

日志了。

ProgramExecute("cmd.exe /c echo ---------------------->> E:\\我是cmd命令行log.txt");
ProgramExecute("cmd.exe /c echo %date%>>E:\\我是cmd命令行log.txt");
ProgramExecute("cmd.exe /c echo %time% >>E:\\我是cmd命令行log.txt"); //Return-Type: unsigned long int
ProgramExecute("cmd.exe /c echo 我按下了按钮 >>E:\\我是cmd命令行log.txt");
ProgramExecute("cmd.exe /c echo. >>E:\\我是cmd命令行log.txt");
ProgramExecute("cmd.exe /c echo --------------------->> E:\\我是cmd命令行log.txt");

  我通过上面的代码,就在E盘符下面生成了一个日志文件。如下图所示:

  图 WinCC中利用cmd命令生成日志文件

四、结语

  上面的命令执行的时候有很多的命令行窗口,其实我们可以将这些写成一个命令行脚本,同时还可以在

WinCC中设置一个项目函数,传递参数的方式执行,这样就不会有很多命令行窗口一闪而过,项目函数执行

的方式待续。

--------------------------------------------------------------分割线---------------------------------------------------------------

1、文章均为个人原创,欢迎转载,转载请保留出处:https://www.cnblogs.com/volcanol/

2、获取工控PLC、变频器、HMI、计算机、Windows、Linux、嵌入式资料点击:获取资料

3、如果您觉得文章对您有帮助可转至页面上半部分打赏,或移步:打赏 

4、或者在页面右下角点推荐哟!!!

--------------------------------------------------------------分割线--------------------------------------------------------------

工控随笔_07_西门子_WinCC利用命令行实现操作log日志的更多相关文章

  1. 工控随笔_18_西门子_WinCC的VBS脚本_07_变量作用域和传值、传址

    在vbs脚本中也存在和其他编程语言一样的概念,那就是变量的作用域,变量的作用域决 定在什么范围内可以访问. 同样的在vbs脚本中对于变量也有一个生命周期, 变量的生命周期决定了变量的存续时间 这个主要 ...

  2. 工控随笔_02_西门子_WinCC的IO域利用C脚本返回值

    WinCC的输入输出域用来显示信息或者接受操作人员的输入.当作为显示功能时,只有直接的变量连接 才能正常的显示,如果使用动态对话框进行设置且用了表达式则不能正确显示. 但是有时候我们在WinCC变量管 ...

  3. 工控随笔_21_西门子_WinCC的VBS脚本_10_对象_01

    最近有点小忙,各种事情,心情也不是很好,烦心事特别多,因此最近更新的比较慢. 不敢再松懈了,今天正好有点时间,就继续看了一下VBScript中关于对象的一些内容. 一.对象 OOP是编程规模发展到一定 ...

  4. 工控随笔_13_西门子_WinCC的VBS脚本_04_变量类型之二

    上一个随笔说了一些关于vbs变量类型的内容,这一篇我们继续说说变量类型相关的内容. 一.NULL补充内容 '需要注意的是,NULL不能简单通过 = 来进行比较,而必须通过 'IsNull函数来实现 ' ...

  5. 工控随笔_10_西门子_WinCC的VBS脚本_01_基础入门

    很多人都认为VB语言或者VBS脚本语言是一种很low的语言,从心里看不起VB或者VBS, 但是其实VBS不仅可以做为系统管理员的利器,同样在工控领域VBS语言大有用武之地. 西门子的WinCC提供了两 ...

  6. 工控随笔_15_西门子_WinCC的VBS脚本_05_变量类型之三_VBS数组

    数组是一种复杂数据类型,不但有数组本身的数据类型: 数组,还有数组元素中存储的数据的类型. 一.vbs中的数组类型 在VBS中提供了两种数组类型,一种是固定数组,一种是动态数组. 1.固定数组 就是在 ...

  7. 工控随笔_12_西门子_WinCC的VBS脚本_03_变量类型

    说到编程语言,总是绕不开数据类型,因为数据类型决定了数据可以进行什么样的操作.同时数据类型 从广义上来说是一种数据结构,在过程式编程的过程中,曾经有过这样一种说法: 程序 = 数据结构 + 算法 可见 ...

  8. 工控随笔_11_西门子_WinCC的VBS脚本_02_运算符

    VBS脚本做为编程语言,提供了很多的运算符,通过这些运算符,可以实现不同的操作.运算符具有不同的类型 不同的运算符之间具有运算优先级. 一.运算符的分类 大体分为以下几类: 1.赋值运算符 2.算术运 ...

  9. 工控随笔_20_西门子_WinCC的VBS脚本_09_常量和流程控制_02

    vbs不但提供了分支结构,还提供了丰富的循环形式.一共有3种循环: 1.for循环 2.do...loop循环 3.while循环 各种循环有各自的特点,在使用的时候可以进行转换. 前面已经描述过Fo ...

随机推荐

  1. GitHub网站使用的基础入门

    github基本入门,首先需要掌握一些ssh非对称加密的知识和一些基本的git命令操作.下面是我推荐的两个比较好的网站,然后我再专门对GitHub网站使用进行步骤讲解. git 命令:http://b ...

  2. topological sort

    A topological sortof a dag G  is a linear ordering of all its vertices such that if G contains anedg ...

  3. 如何开发微信小程序学习

    文件中 project.config.json是开发者工具为我们自动生成的一个开发者工具的配置文件,主要是保存了一些我们对开发者工具的个性化配置. 一个微信小程序应用至少要有两个文件 一个是app.j ...

  4. freeswitch配置功能二

    <?xml version="1.0" encoding="utf-8"?><include>        <context n ...

  5. 小伙 zwfw-new.hunan.gov.cn.iname.damddos.com [222.240.80.52]

    由于这个应用出问题非常影响用户体验:于是立马让运维保留现场 dump 线程和内存同时重启应用,还好重启之后恢复正常.于是开始着手排查问题.

  6. Gravatar 头像使用

    Gravatar :如果在Gravatar的服务器上放置了你自己的头像,那么在任何支持Gravatar的blog或者留言本上留言时,只要提供你与这个头像关联的email地址,就能够显示出你的Grava ...

  7. Vue基础之数据绑定

    我们学习一门新语言或者框架时,第一件事是什么呢,那必然是向世界say Hello. 创建一个Vue应用 话不多说,先上代码,让我们感受一下Vue的核心功能 <!DOCTYPE html> ...

  8. conts、var 、let的区别

    1.const定义的变量不可以直接修改,通过 this.a = 'kkk' 进行修改, 而且必须初始化. 2.var定义的变量可以修改,如果不初始化会输出undefined 3.let是块级作用域,函 ...

  9. mybatis 学习笔记 -详解mybatis 及实例demo

    快速入门1 要点: 首先明白mybatis 是什么 这是一个持久层的框架.之前叫做ibatis.所以,在它的代码中出现ibatis这个词的时候,不要感到惊讶.不是写错了,它确实就是这个样子的. 首先, ...

  10. CentOS官网下载系统镜像

    https://jingyan.baidu.com/article/1876c85279cedd890a13766c.html