会员登录 - 用户注册 - 网站地图 Office中国(office-cn.net),专业Office论坛
当前位置:主页 > 技巧 > Access技巧 > 模块函数VBA > 正文

用VB轻松调用其他程序

时间:2004-10-29 15:46 来源:本站原创 作者:佚名 阅读:
用VB轻松调用其他程序

                            陈小勇

  我们编写程序时,有时会遇到在一个程序中调用并控制另一个程序执行的情况,在一些编程语言中实现起来较为繁琐,但如果用VB编写时,则可轻松实现。下面我就以在程序中调用“计算器”为例,总结了以下几种方法:

  一、以异步方式来执行其他程序

  Shell 函数是以异步方式来调用其他程序的。也就是说,用Shell启动的程序可能还没有完成执行过程,就已经执行到 Shell 函数之后的语句。

  语法:Shell(pathname[,windowstyle])

  说明:pathname:必要参数。Variant (String),要执行的程序名,以及任何必需的参数或命令行变量,可能还包括目录或文件夹,以及驱动器。

  例如:RetVal = Shell(″C:\WINDOWS\CALC.EXE″, 1) ′ 调用计算器。

  二、以同步方式来执行其他程序

  有时候,我们需要让VB在执行完外部程序后再执行下一语句,这就需要使用API函数。

  我们可通过OpenProcess和CloseHandle函数来检测调用软件的运行情况。这两个函数的声明如下:

  Declare Function OpenProcess Lib ″kernel32″ Alias ″OpenProcess″ (ByVal dwDesiredaccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long

  Declare Function CloseHandle Lib ″kernel32″ Alias ″CloseHandle″ (ByVal hObject As Long) As Long

  建立下面函数,用以判断程序是否在运行,如果是,则在运行时返回True。

  Function IsRunning(ByVal ProgramID) As Boolean  ′传入进程标识ID

    Dim hProgram As Long   ′被检测的程序进程句柄

    hProgram=OpenProcess(0,False,ProgramID)

    If Not hProgram=0 Then

     IsRunning=True

    Else

     IsRunning=False

    End If

    CloseHandle hProgram

  End Function

  例如要调用计算器(CALC.EXE)并等到它运行完成后再执行下一语句,可以使用以下代码:

   Dim RetVal

   MsgBox ″开始运行″

   RetVal = Shell(″C:\WINDOWS\CALC.EXE″, 1)

   While IsRunning(RetVal)

     DoEvents

   Wend

   MsgBox ″结束运行″

  三、关闭正在运行中的其他软件

  如果要在程序中关闭正在运行中的其他程序,可以先使用FindWindow函数找出相应的程序句柄,然后调用PostMessage函数关闭该程序即可。

  这两个函数的声明如下:

  Declare Function FindWindow Lib ″user32″ Alias ″FindWindowA″ (ByVal lpClassName As String, ByVal lpWindowName As String) As Long

  Declare Function PostMessage Lib ″user32″ Alias ″PostMessageA″ (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As Long) As Long

  例如要检测“计算器”程序是否正在运行,如果是则关闭它,可以使用如下代码来实现:

   Dim winHwnd As Long

   Dim RetVal As Long

   winHwnd=FindWindow(vbNullString,″计算器″)

   If winHwnd〈〉0 Then

     RetVal=PostMessage(winHwnd,&H10,0&,0&)

     If RetVal=0 Then

        MsgBox ″关闭计算器出错!″

     End If

   Else

     MsgBox ″计算器程序没有运行。″

   End If

(责任编辑:admin)

顶一下
(0)
0%
踩一下
(0)
0%
发表评论
请自觉遵守互联网相关的政策法规,严禁发布色情、暴力、反动的言论。
评价: