1、问: 如何触发计算机扬声器的声音? 答: 编写如下C-Action: #pragma code(\"kernel32.dll\");
BOOL Beep(DWORD dwFreq,DWORD dwDuration); #pragma code(); Beep(500,500);
2、问: 如何通过C脚本来确定报警信息?
答: 首先必须在画面中插入报警控件,可以用如下两种方式来确认信息: (1)、确认单条信息
4版本和高于此版本的WinCC
BOOL OnBtnSinglAckn(char*lpszPictureName,char*lpszObjectName) 5版本和高于此版本的WinCC
BOOL AXC_OnBtnSinglAckn(char*lpszPictureName,char*lpszObjectName)
(2)、确认报警窗口所有可见的报警 4版本和低于此版本的WinCC
BOOL OnBtnVisibleAckn(char*lpszPictureName,char*lpszObjectName)
5版本和高于此版本的WinCC
BOOL AXC_OnBtnVisibleAckn(char*lpszPictureName,char*lpszObjectName)
3、问: 如何在WinCC中读取系统时间? 答: 通过如下C-Action: #pragma code(\"kernel32.dll\");
Void GetLocalTimes(SYSTEMTIME*lpst); #pragma code();
SYSTEMTIME time; GetLocalTime(&time);
SetTagWord(\"Varname\ SetTagWord(\"Varname\
SetTagWord(\"Varname\ SetTagWord(\"Varname\ SetTagWord(\"Varname\ SetTagWord(\"Varname\ SetTagWord(\"Varname\
SetTagWord(\"Varname\
4、问: 如何经Windows对话框设置日期时间? 答: 通过调用Windows对话框实现。具体如下: #include\"apdefap.h\"
void onClick(char*lpszPictureName,char*lpszObjectName,
char*lpszPropertyName)
{ProgramExcute(\"c:\\\\win98\\\\control.exe timedate.cpl\");} 其中执行的程序路径,需根据具体情况填写。
5、问: 如何在WinCC中调用SQL语言?
答: 1、创建一个 SQL文件,此文件在ISQL中建立,文件内包含所要执行的SQL语句。Windows对话框实现。具体如下:
2、在WinCC中用C Script 调用上述SQL文件,如下所示: #include\"apdefap.h\"
void OnLButtonDown(char* lpszPictureName, char* lpszObjectName, char* lpszPropertyName, UINT nFlags,int x,int y) {
char*a=\"c:\\\\siemens\\\\common\\\\SQLANY\\\\ISQL-q-b-c UID=DBA;PWD=SQL;DBF=E:\\\estsql\\\estsqlRT.DB; DBN=CC_testsql_99-12-03-12:48:26R;READ E:testsql\\\est.sql\"; Printf(\"%s\\r\\n\ ProgramExcute(a); }
下面是一个简单的SQL文件内容: select *from pde#hd#t#test;
output to e:\\\est2.txt FORMAT ascii 注意:文件名及路径中不要带空格。
6、问: 如何整点启动归档?
答: 在\"Globle Script\"下的Project function编写程序函数:cyclicarchive BOOL cyclicarchive() {
#pragma code(\"kernel.dll\");
void GetLocalTime(SYSTEMTIME*lpsz); #pragma code();
SYSTEMTIME time; Int t1;
GetLocalTime(&time); T1=time.wMinute; If(t1==00) {
SetTagBit(\"startarchive\
Return(BOOL) (GetTagBit(\"startarchive\"));
} }
在Tagloging中的\"Properties of process tag\"中的\"archive tag\"Tab下的Archive type选择Cycle-selective,在\"Event\"标签下的\"StartEvent\"内选择cyclicarchive函数。
7、问: How can I set and reset a WinCC variable by mouse click with C script?
答: The following function shows how you can alternately set and reset a WinCC variable by mouse click.
#include \"apdefap.h\"
void OnClick(char* lpszPictureName, char* lpszObjectName, char* lpszPropertyName) {
BOOL z;
z=GetTagBit(\"MyBitVariable\"); if (z==0)
SetTagBit(\"MyBitVariable\ else
SetTagBit(\"MyBitVariable\ }
8、问: How can I program a waiting function (Sleep) in WinCC? 答: The following sample program shows how the \"Sleep\" is used. #pragma code(\"Kernel32.dll\") void Sleep(int milliseconds); #pragma code()
Sleep(1000); //time specification in milliseconds Warning:
If you use Sleep(), processing the C script is interrupted for the time indicated. Requests for the interrupted function cannot be processed during this time.
9、问: How can I output a SIMATIC timer minutes and seconds in WinCC?
答: If you want to output a SIMATIC Timer in minutes and seconds in WinCC, then in WinCC please use a static text in the Graphics Designer to which you interface the following action:
char* _main(char* lpszPictureName, char* lpszObjectName, char* lpszPropertyName) {
char *p;
DWORD hilf; int min, sec; p=SysMalloc(10);
hilf=GetTagDWord(\"Time\");
min=hilf/60000;
sec=hilf%60000/1000;
sprintf(p,\"%d min %d sec\ return p; }
The \"Time\" variable linked to the I/O field must have the following properties: •Data type \"32-bit value without sign\"
•Format adaptation \"DwordToSimaticBCDTimer\" •Address: data area \"Times\" and addressing \"Word\" 21: WINCC--如何在程序中动态修改用户密码
1、点击“开始”--》“设置”--》“控制面板”--》“管理工具”--》“数据源(ODBC)”,打开ODBC数据源管理器 2、在用户DSN页面的用户数据源中找到与当前项目所关联的一项,其名称为“CC_项目名_项目建立日期时间”,记下该项的名称 3、在脚本中加入以下代码: #pragma code(\"UseGen.dll\") #include \"USEGENAP.H\" #pragma code()
LPCMN_ERROR err; //定义的LPCMN_ERROR型变量,在函数调用中需使用
if (PWGENConnect(\"CC_ass_04-09-21_16:35:22\//建立与数据库的联接,其中CC_ass_04-09-21_16:35:22用第二步中记下的名称取代 { if (PWGENChangePassword(GetTagChar(\"user\"),GetTagChar(\"oldpassword\"),GetTagChar(\"password\"),err)) //修改密码,user,oldpassword,password分别为存贮用户名,原密码,新密码的内部变量,类型为文本变量8位字符集 {
//密码修改成功后的操作,如给用户提示等 } }
PWGENDisconnect(err); //断开与数据库的联接 4、编译运行程序 5、工作完成 6、与用户管理相关的函数定义存贮在APPLIB目录下的USEGENAP.H文件中,可根据上面示例自行完成添加用户,修改权限等功能。
22:WinCC6.0 中归档时和5.1版本为什么不同了?
WinCC V6.0 的后台数据库采用了MS SQL Server 2000,所以归档方式与V5.1 有所不同,它的运行数据存放在数据片段(segment)当中,工程师可以根据尺寸需求组态最大容量或根据时间周期启动新的数据库归档片段。将归档数据连续的写入数据库,单个数据片段的尺寸到达或者时间界限到达时,系统会自动开启另一个数据片段进行归档。当数据片段的总体尺寸达到最大时,最早的数据片段就会被覆盖,重新开始新的归档。
23:WinCC6.0 中如何设定归档周期?
WinCC V6.0 版本中的快慢速归档的归档周期界限可以由用户自行设 定,该参数在快速归档属性的第三个标签项中设置。
24:如何计算慢速归档数据库的尺寸?
慢速归档时一条变量归档记录占用32 字节的空间,每个变量以2 分钟为归档周期,一周之内会产生5040 条记录,若有5000 个变量的归档,则单个数据片段的大小计算为: 32×5000×5040=8000000 byte ==> 约等于800MB 考虑到留出20%的余量,设定单个数据片段为1G
所有数据归档期限是两个月,因此所有段的尺寸为单个片段尺寸乘以单个片段的个数, 即:1GB×9=9GB
25:如何计算快速速归档数据库的尺寸?
快速归档时一条变量归档记录占用3 字节的空间,每个变量以2 秒钟为归档周期,一周之内会产生302400 条记录,若有50 个变量的归档,则单个数据片段的大小计算为: 3×50×302400=45360000 byte ==> 约等于46MB 考虑到留出20%的余量,设定单个数据片段为60MB
所有数据归档期限是两个月,因此所有段的尺寸为单个片段尺寸乘以单个片段的个数,即:60MB×9=0MB
26:所有的归档变量都可以计算出它占用的数据库大小吗?
只有周期连续归档的数据才能定量的计算其占用的数据库尺寸,因此当您对应设定的时间期限计算并设置数据库尺寸大小时,需要考虑其他数据归档类型的数据,留出相应的余量。
27:WinCC V5.1 中文版的安装要求是什么?
1)WinCC V5.1 亚洲版只有V5.1 这一个版本,不再有后继版本,WinCC V5.1 亚洲版应安装在Windows 2000 SP2 操作系统上
2) WinCC 的语言版本应和操作系统的语言版本相对应,不建议将中文WinCC 装在英文操作系统上
28:有没有快捷的方法如何将WinCC的实时数据通过OPC DA记录到MS Access、MS SQL Server和Oracle数据库中?
可以使用WinCC Industrial Data Bridge将WinCC的实时数据通过OPC DA记录到MS Access、MS SQL Server和Oracle数据库中,但是需要授权,分为以128、 512、2K和10K
29:WinCC 能提供的最高变量刷新速度是多少? 对于一般的网络通讯方式来说,WinCC 能提供的最高刷新速度是250 毫秒,但WinCC 采用RawData 归档数据链接的方式可以实现对S7-400PLC 的高速数据采集。
30:如何实现WinCC 高速数据采集?
WinCC 采用RawData 归档数据链接的方式可以实现对S7-400PLC 的高速数据采集。原理是PLC 将每个循环周期所采集的过程值(或PLC 以其他方式得到的数据或数据包)以一定的顺序存放在具有一定的格式的DB 块中,当到达一定的数量后,PLC 可以调用系统功能块 SFB37(AR_Send)将这个DB 块主动地发送给WinCC, 然后WinCC 会在后台
自动调用标准化DLL 来拆解数据,并将其按时间顺序保存在数据库中。在WinCC 的过程画面中,可以使用在线趋势控件或在线表格控件来查看所采集的数据。
由于是批量传送,可以有效地提高通讯效率,使高速数据采集成为可能,而这时所谓的采集频率就取决于你对保存在DB 块中的各过程值间的时间间隔的定义。可以定义的最小的时间间隔是1 毫秒。但如果是PLC 每个循环周期采样一次,那么定义的时间间隔应大于PLC 循环周期。DB 块的最大尺寸是16KB。
技巧:可以考虑使用多DB 块进行缓冲并添加程序控制DB块的写入和发送顺序,能够实现连续的采集,但要充分考虑CPU 的负载和循环周期。
31:WinCC 高速数据采集的前提条件是什么? 1) WinCC 的版本为 V5.1 或更高 2) S7-400 系列CPU
3) WinCC 站与S7 400 站建立S7 连接(包括MPI,ProfiBus,TCP/IP,工业以太网都可以实现)
32:为什么我无法从WinCC里调用STEP 7 变量?
从WinCC里调用STEP 7 变量的前提条件是,WinCC的项目文件必须是集成在STEP 7项目中的。
在安装所有Simatic 软件前,请查阅软件的安装注意事项,确定操作系统与软件的兼容性。该文档一般位于:CD\\Documents\\<语言版本>\\InstallNotes.chm。 要使用WinCC与STEP 7的集成功能,WinCC和STEP 7必须安装在同一台计算机上,必须在安装WinCC之前安装STEP 7。STEP 7 与WinCC的版本必须一致。 33:如何把现成的WinCC项目集成到STEP 7 项目中?
如果你在一台计算机上已经安装了兼容的WinCC和STEP 7,并且有了一个单独使用的WinCC项目,想把它集成到一个已有的STEP 7项目中去。那么,你必须先添加与集成相关的WinCC组件。把WinCC光盘放入光驱,并启动WinCC的安装程序。添加与集成相关的WinCC组件。
按如下步骤把已有WinCC项目文件插入STEP 7项目文件
1.在STEP 7项目文件中插入一个OS站,然后把它改名为已有的WinCC项目名称。 2.在STEP 7项目里删除因仅插入OS站而产生的WinCC项目文件,其位置在STEP 7 项目文件夹里的wincproj文件夹下,例如:d:\\siemens\\STEP7\\S7proj\\STEP7_Integration\\wincproj\\'Name of the OS'
3.最后在项目复制器里用’Save as’把已有的WinCC项目文件存储到STEP 7项目路径下。项目复制器位于开始菜单项\"Start > SIMATIC > WinCC > Tools\"。
注意:对于集成STEP 7项目里的WinCC项目,你也可以使用压缩工具(Packer)来归档WinCC项目。
34:wincc怎样和s7plc-sim连接?
要访问PLCSIM模拟软件,必须按如下方法操作,按照以下的顺序来安装程序: STEP 7 V 5.x
PLCSIM V4.x以上 WinCC V5.x
选择用户自定义安装。 对于SIMATIC WinCC V5
SP1及以下版本的用户,在“通讯”组件下,必须选择“S7Dos”和“对象管理器”组件。 对于SIMATIC WinCC V5
SP2及更高版本的用户,“S7Dos”是自动安装的。就是说不再需要在“用户自定义安装”下选择该选项。在PG/PC界面上做如下设置:在控制面板中双击“设置PG/PC界面”。在“应用程序的访问点”域中,选择“MPI
(WinCC)”。在“使用的界面参数”域中选择“<无>”。启动应用程序STEP 7: 启动SIMATIC管理器 启动PLCSIM
打开要模拟的项目或组态一个项目。 在项目中添加一个OS。 在PLCSIM中加载项目。
启动WinCC并创建一个新项目或打开已有的项目。 WinCC
添加“SIMATIC S7 PROTOCOL SUITE”到变量管理器。 在MPI下添加一个新连接。 右击该连接然后选择“属性”。 点击“属性”按钮。
在“连接”标签中指定MPI地址和已在STEP 7中组态好的CPU的插槽。 确认所做的指定。 激活WinCC项目。
进入“开始 > SIMATIC > WinCC > 工具 > 通道诊断”。在“通道连接”下可以显示连接的状态。
如果连接没能设好:在WinCC资源管理器中的“系统参数 - MPI > 单元”中,启用选项“自动设置”。
在“系统参数 - MPI > 通道”中,取消“使用PLC的循环读取服务”选项。 wincc和西门子PLC仿真通讯需要PLCSIM ,先将PLCSIM
运行,建立一个WINCC项目,使用MPI通讯即可,说白了跟MPI通讯一样,只是PLC是用PLCSIM 在计算机上模拟的
但是有一点要注意的是,这种方式下不能使用输入区(I区),凡是有输入的地方都要用M区来代替
可以使用输入区(I区),只是有些特殊功能不能用。
35:WINCC-如何使用自定义的对话框实现用户登录?
在登录按钮中加处以下脚本: #pragma code(\"useadmin.dll\")
#include \"PWRT_API.H\"
#pragma code()
if (PWRTSilentLogin(\"username\ {
//登录成功后的处理 }
其中\"USERNAME\可以用存储用户名和密码的变量替换.如: PWRTSilentLogin(GetTagChar(\"user\"), GetTagChar(\"PassWord\"))
当登录成功时,函数返回值为真;如登录失败,则返回值为假。
36:WINCC-如何使用自定义的对话框实现用户退出? 实现登陆:
#pragma code(\"\"useadmin.dll) #include \"PWRT_api.h\" #Pragma code() PWRTlogin('1'); 实现退出:
#pragma code(\"\"useadmin.dll) #include \"PWRT_api.h\" #Pragma code() PWRTlogout();
37:如何把GIF图片放到wincc中?
首先插入aniGIF.ocx这个ole控件,然后双击它,在GIF属性中选择您需要显示的GIF图片就可以了。
38:如何将低版本创建的项目移植到WinCCV6.0中? 将项目移植到WinCC V6.0的工作步骤:
WinCC V6.0与其以前的版本相比在数据组织方面有着显著的不同。为了使在WinCC V5.0 Service Pack2或WinCC V5.1中创建的项目在WinCC V6.0中也能工作,项目数据必须首先通过移植作相应的调整。为此,WinCC V6.0提供了一个项目移植器,用于自动移植项目的组态数据、运行系统数据和归档数据在移植之前,建议为原版本的项目做一个备份。与此有关的信息参见WinCC信息系统中的主题“使用WinCC”>“使用项目”>“复制和归档项目”。
已归档的文件:如果必须访问先前版本的归档数据,则必须将归档移植到WinCC V6.0。请使用项目移植器移植归档数据和dBASE III归档。
多用户项目:为了使利用WinCC V5.0 SP2或V5.1所创建的多用户项目在WinCC V6.0中能够正常工作,可进行如下操作:
移植系统中所有服务器上的单个多用户项目。如果原来的项目使用了多客户机,则分别单独移植多客户机的项目数据。正常操作中的冗余系统,不用取消激活操作就可在冗余系统中对项目进行升级。此时,将按规定的次序升级服务器、客户机和多客户机。章节“在正常操作中升级冗余系统”中提供了有关的详细说明。
警惕:为了不影响系统操作,必须遵守所描述的步骤次序,且完成所有步骤时不能有任何长时间的中断。
早于WinCC V5.0 Service Pack 2的WinCC版本:对于早于WinCC V5.0 SP2的WinCC版本所创建的项目,必须一步一步地进行移植,将系统先升级到WinCC V5.1,并移植项目。安装WinCC V6.0,并使用项目移植器移植项目。
39:wincc6.0中支持ab plc的驱动吗? WinCC V6.0将不再提供下列通讯通道: Allen Bradley DH DH+ DH485 Allen Bradley Serial DF1
Applicom Multi Protocol Interface GE Fanuc SNP SNPX Mitsubishi FX
Modbus Protocol Suite Modbus Serial
SIMATIC S5 PMC Ethernet SIMATIC S5 PMC Profibus SIPART
可以用OPC来替代。某些通道需附加件的支持。 40:WINCC的授权坏了,显示“Authorization SIK/SIMATIC WINCC RT 128 PowerTags is faulty.”,重新安装显示已经存在此授权,请问要怎么处理?
可以询问原来的销售商索要一个激活码,可以在authorsw中manageauthorization中右键单击选择“recover autrorization”输入激活码激活授权即可。 41:用C编程解决授权点数不够用的问题(acsun提供)
当需要的工艺参数超过WinCC版本的Tag数目,可以用C语言编程实现多个工艺参数打包成一个Tag传送.例如某个配料称重系统有146个参数超过了WinCC的128个Tag的就可以用C语言编程决这一问题而不需要购买更高的授权.
基本思想就是把多个参数在下位机内存中连续排列然后在WinCC中定义一个Tag它的长度是多个参数之和取得这个Tag后编程将其分成多个参数
例如下位机有两个参数LTN44001和LTN44023都是16位整数分别存放在DD99.DW146和DD99.DW148
在WinCC中定义一个外部Tag命名为PackageTag类型为32位整数并联地址为DD99.DBD146再定义两个内部tag名为LTN44001和LTN44023在 Global Script全局脚本中C语言编程如下 Union {
Long Dword Int Word[2] }union
Union.Dword=GetTagDword(\"PackageTag\") SetTagWord(\"LTN44001\SetTagWord(\"LTN44023\
这样两个参数LTN44001和LTN44023就通过一个Tag传送上来了理论上只要下位机内存足够可以传送任意数量的参数而不受WinCC版本外部Tag数目的.
42:如何在WinCC里用C语言调用SQL语言?
1、创建一个SQL文件。
此文件在ISQL中创建,文件内容是所希望执行的SQL语句。
2、在WinCC的C Script中编写程序调用此SQL文件,如以下程序所示: #i nclude \"apdefap.h\"
void OnLButtonDown(char* lpszPictureName,
char* lpszObjectName,
char* lpszPropertyName,
UINT nFlags, int x, int y) {
char*a=\"C:\\\\SIEMENS\\\\Common\\\\SQLANY\\\\ISQL-q-b-c
UID=DBA;PWD=SQL;DBF=E:\\\estsql\\\estsqlRT.DB;
DBN=CC_testsql_99-12-03_12:48:26R;
READ
E:\\\estsql\\\est.sql\";
printf(\"%s\\r\\n\
ProgramExecute(a); }
下面是一个简单的SQL文件内容:
select * from pde#hd#t#test;
output to E:\\\est2.txt FORMAT ascii 注意:文件名及路径中不要带空格。
43:如何整点启动归档?
在\"Global Script\"下的Project functions编写函数:cyclicarchive
BOOL cyclicarchive()
{
#pragma code (\"kernel32.dll\");
void GetLocalTime (SYSTEMTIME* lpst);
#pragma code();
SYSTEMTIME time;
Int t1;
GetLocalTime(&time);
t1=time.wMinute;
if(t1==00) {
SetTagBit(\"startarchive\
return(BOOL)(GetTagBit(\"startarchive\")); } }
在Tagloging中的\"Properties of process tag\"中的\"Archive Tag\"tab下的Archiving type选择Cycle-selective,在\"Event\"标签下的\"Start Event\"内选择cyclicarchive函数。
44:如何在按键组合被禁用的情况下,从WinCC运行环境进入WinCC Control Center? 最好是做一个按钮,该按钮需要用用户权限保护,在该钮中编写如下C-action:
低于WinCC 5.0版本:
#pragma code (\"user32.dll\");
BOOL SetForegroundWindow(HWND);
#pragma code();
HWND handle;
handle=FindWindow(\"MCPFrameWndClass\
If (!SetForegroundWindow(handle))
Printf (\"\\r\\n SetForeground fails\");
WinCC 5.0版本以及更高的版本:
#pragma code(\"user32.dll\");
BOOL SetForegroundWindow(HWND);
#pragma code();
HWND handle;
handle=FindWindow(\"WinCCExplorerFrameWndClass\
If (!SetForegroundWindow(handle))
Printf (\"\\r\\n SetForeground fails\");
45:WinCC如何实现鼠标OnMouseOVer事件?
用WINDOWAPI函数GetCusorPos获取当前鼠标位置,用GetWindowRect函数获取窗口位置,两值相减得鼠标在WINCC frame上的相对位置。用全局脚本(设定为1s定时刷新),然后获取要OnMouseOver事件的物体的位置,并与鼠标位置相比较,如一致则触发自己定义的动作。
#i nclude \"apdefap.h\"
int gscAction( void ) {
#pragma code(\"user32.dll\");
BOOL GetCusorPos(POINT lpPoint); //获取鼠标的位置(绝对位置-对应屏幕分辨率) BOOL GetWindowRect(HWND hwnd,LPRECT lpRect); //获取窗体位置 #pragma code(); POINT pPos; RECT rRec; HWND hwnd; BOOL bRet,bRet2;
long lLeft,lTop,lWidth,lHeight; long lX,lY;
char szStr[100];
hwnd=FindWindow(NULL,\"WinCC-Runtime - \"); //如语言为中文应为\"WinCC 运行系统-\"
if (hwnd==0) {printf(\"\\r\\nError! WinCc Handle is %d\
bRet=GetCursorPos(&pPos); if (bRet==0) goto over;
bRet2=GetWindowRect(hwnd,&rRec); if (bRet2==0) goto over;
lX=pPos.x-rRec.left; //鼠标 对{置 lY=pPos.y-rRec.top; //鼠标 位置
//如果为非全屏模式,需将上述数值中的高height判断减去标题栏的宽度 //printf(\"The Current Cusor Pos is x:%d,y:%d\\r\\n\
//printf(\"The Cusor Pos in Window is x:%d,y:%d\\r\\n\lLeft=GetLeft(\"NewPdl0.Pdl\lTop=GetTop(\"NewPdl0.Pdl\lWidth=GetWidth(\"NewPdl0.Pdl\lHeight=GetHeight(\"NewPdl0.Pdl\
if ((lX>=lLeft)&&(lY>=lTop)&&(lX<=lLeft+lWidth)&&(lY<=lTop+lHeight)) {
sprintf(szStr,\"%d,%d\
SetText(\"NewPdl0.Pdl\ }
//printf(\"The Text1 Pos is x:%d,y:%d\\r\\n\over: return 0; }
46:如何实现ASP与WinCC V6数据库sql server 2000的连接?
WinCC V6用ODK获取DSN名,{后生成网址字符串,再用shellExecuteA函数打开网页 //---------------------------------------------------------------------------------- #pragma code(\"shell32.dll\")
long ShellExecuteA(HWND,LPCTSTR,LPCTSTR,LPCTSTR,LPCTSTR,int); #pragma code()
char dsnStr[100]; HWND hwnd;
sprintf(dsnStr,\"http://dcount/test.asp?dsnStr=%s\",GetDSN(1)); //Return-Type: LPCTSTR printf(\"\\r\\n%s\
hwnd=FindWindow(NULL,\"WinCC - Runtime \");
ShellExecuteA(hwnd,\"open\//-------------------------------------------------------------------------------------
ASP方面需要注意的是连接字符串的形式与普通acess ODBC不太一样,而且需要用户名和密码
由于WINCC封装的sa用户的密码暂时不知道,所以必须用SQL Server EnterPrise Manager建立自己的用户,添加system Administrator权限就可以了!否则会出现错误提示 Microsoft OLE DB Provider for SQL Server 错误 '80040e4d' Login failed for user 'sa'.
'-------------------------------------------------------------------------------------- dsnStr=request(\"dsnStr\")
set conn=server.createobject(\"adodb.connection\") set rs=server.createobject(\"adodb.recordset\") conn.Provider = \"sqloledb\"
conn.open \"Server=DCOUNT\\WINCC;Database=\" & dsnStr & \";UID=dcount;pwd=;\" rs.open \"select * from test\response.write rs.recordcount do while not rs.eof
response.write rs(\"f1\") & \"---\" & rs(\"f2\") & \"---\" & rs(\"f3\") rs.movenext loop rs.close conn.close
47:如何在退出WINCC监控时直接关闭电脑? 1.利用动态向导
2.在脚本中加入 DMExitWinCCEx (DM_SDMODE_SYSTEM);也可以
48:如何通过WINCC API函数读出当前报警消息?
1、使用GMsgFunction中读出当前报警信息的ID(dwMsgNr);
2、使用MSRTGetMsgCSData函数读出该报警信息ID对应文本库TEXTLIB中的文本ID(dwTextID1);
3、使用MSRTGetMsgText函数读出该文本ID的文本。 信息到达处理:如果读取文本成功,则置文本变量MSG。
信息离去处理:如果MsgNr与上一次相同,则复位MSG,如果不是,则继续保持信息。 具体函数说明请看ODK文档
BOOL GMsgFunction( char* pszMsgData) {
#pragma code(\"msrtcli.dll\") #i nclude \"msrtapi.h\"
#pragma code();
MSG_TEXT_STRUCT tMeld; MSG_CSDATA_STRUCT sM; CMN_ERROR err; BOOL bRet;
DWORD dwTextID1; DWORD dwMsgNum; char szMsg[255];
#define TAG_MSG \"MSG\"
MSG_RTDATA_STRUCT mRT;
memset( &mRT, 0, sizeof( MSG_RTDATA_STRUCT ) );
if( pszMsgData != NULL ) {
printf( \"Meldung : %s \\r\\n\
sscanf( pszMsgData, \"%ld,%ld,%04d.%02d.%02d,%02d:%02d:%02d:%03d,%ld, %ld, %ld, %d,%d\
&mRT.dwMsgNr, // Meldungsnummer
&mRT.dwMsgState, // Status MSG_STATE_COME, .._GO, .._QUIT, .._QUIT_SYSTEM
&mRT.stMsgTime.wYear, // Tag &mRT.stMsgTime.wMonth, // Monat &mRT.stMsgTime.wDay, // Jahr &mRT.stMsgTime.wHour, // Stunde &mRT.stMsgTime.wMinute, // Minute &mRT.stMsgTime.wSecond, // Sekunde
&mRT.stMsgTime.wMilliseconds, // Millisekunde
&mRT.dwTimeDiff, // Zeitdauer der anstehenden Meldung &mRT.dwCounter, // Interner Meldungsz?hler &mRT.dwFlags, // Flags( intern ) &mRT.wPValueUsed, &mRT.wTextValueUsed );
//**************************************************************************************code for dcount
if (mRT.dwMsgState==MSG_STATE_COME)//信息到达处理 {
dwMsgNum=mRT.dwMsgNr;
printf(\"\\r\\nThe Alarm Message No is %d !\\r\\n\ bRet=MSRTGetMsgCSData(dwMsgNum,&sM,&err);
if (bRet==TRUE) {
dwTextID1=sM.dwTextID[0];
printf(\"\\r\\nThe TextID of The MessageNr %d is %d !\\r\\n\ bRet=MSRTGetMsgText(1,dwTextID1,&tMeld,&err); if (bRet==TRUE) {
sprintf(szMsg,\"%s\
printf(\"\\r\\nThe Text of TextID %d is %s !\\r\\n\ } } }
if (mRT.dwMsgState==MSG_STATE_GO)//信息离去处理 {
dwMsgNum=mRT.dwMsgNr;
if (dwMsgNum==GetTagDWord(TAG_MSG_NR)) SetTagChar(TAG_MSG,\"\"); }
//**************************************************************************************code for dcount
// Meldungsdaten einlesen
// Prozesswerte lesen, falls gew???????§???1nscht }
printf(\"Nr : %d, St: %x, %d-%d-%d %d:%d:%d.%d, Dur: %d, Cnt %d, Fl %d\\r\\n\" ,
mRT.dwMsgNr, mRT.dwMsgState, mRT.stMsgTime.wDay, mRT.stMsgTime.wMonth, mRT.stMsgTime.wYear,
mRT.stMsgTime.wHour, mRT.stMsgTime.wMinute, mRT.stMsgTime.wSecond, mRT.stMsgTime.wMilliseconds, mRT.dwTimeDiff, mRT.dwCounter, mRT.dwFlags ) ;
SetTagChar(TAG_MSG,szMsg);
return( TRUE ); }
49:如何实现用户登陆日志(wincc中用c脚本实现?)( 柳树成林原创) 用户登陆日志:(包括用户的登陆退出信息,以便查询在什么时间段是哪个用户在使用这个监控软件)
#i nclude \"apdefap.h\"
int gscAction( void ) {
#pragma code(\"kernel32.dll\")
VOID GetLocalTime(LPSYSTEMTIME lpSystemTime); #pragma code()
char* username; char buf[128];
static char preuser[128]; unsigned a,b,c,d,e,f; FILE* fp;
SYSTEMTIME sysTime;
//读取系统时间,并且复制给变量a,b,c,d,e,f GetLocalTime(&sysTime);
a=sysTime.wHour; b=sysTime.wMinute; c=sysTime.wSecond; f=sysTime.wYear; e=sysTime.wMonth; d=sysTime.wDay;
//得到当前用户名称
username = GetTagChar(\"@CurrentUser\"); fp= fopen(\"c:\\\\wincclog.txt\
if(strcmp(username, preuser)!=0) //如果当前用户名称和前一个用户名不同 {
if((strcmp(username, \"\") != 0)&&(strcmp(preuser, \"\") == 0)) //如果当前用户名称不空同时前一个用户名为空 {
sprintf(buf, \"用户:%s\登陆时间是:\ %d-%d-%d,%d-%d-%d\\n\ fputs(buf, fp); } else {
if((strcmp(username, \"\") == 0)&&(strcmp(preuser, \"\") != 0)) //如果当前用户名称为空同时前一个用户名不空
{
sprintf(buf, \"用户:%s\退出时间是:\ %d-%d-%d,%d-%d-%d\\n\ fputs(buf, fp); }
else {
sprintf(buf, \"用户:%s\退出时间是:\ %d-%d-%d,%d-%d-%d\\n\ fputs(buf, fp); sprintf(buf, \"用户:%s\登陆时间是:\ %d-%d-%d,%d-%d-%d\\n\ fputs(buf, fp); } } }
strcpy(preuser, username); fclose(fp);
return 0; }
50:在wincc画面编辑器里注册的OCX控件,由于开发时没有考虑到wincc标准控件中具备层次哪个属性!所以不能够通过画面编辑器里的菜单进行设置OCX控件的层次关系!
建议不要把wincc中注册的OCX控件和wincc本身的标准控件重叠放置,否则wincc本身的标准控件将被覆盖!
因篇幅问题不能全部显示,请点此查看更多更全内容
Copyright © 2019- zicool.com 版权所有 湘ICP备2023022495号-2
违法及侵权请联系:TEL:199 1889 7713 E-MAIL:2724546146@qq.com
本站由北京市万商天勤律师事务所王兴未律师提供法律服务