Access编程交流网
  • 设为首页|收藏本站|繁体中文|手机版
  •     
  • Access培训-Access开发平台-Access行业开发

  • 首页
  • 资讯
  • 技巧
  • 源码
  • 行业
  • 资源
  • 活动
  • 关于

技巧

ACCESS数据库

启动/设置/选项/背景

修复/压缩

安全/加密/解密

快捷键

版本升级/其它等

数据表

命名方式/设计规范

表设计

查询

Sql语言基础

选择查询

更新查询

删除查询

追加查询

生成表查询

交叉表查询

SQL特定查询

查询参数

查询综合应用

界面/窗体/控件

标签

文本框

命令按钮

组合框/列表框

选项组/复选框/选项按钮

选项卡

子窗体

窗体本身/综合应用

其它

报表打印

报表设计

高级报表

模块/函数/VBA/API/系统

VBA基础

内置函数

调试/跟踪/Debug

模块/类模块

API/COM/系统相关

字符数字日期

网络通信游戏

加密解密安全

文件处理

经典算法

宏/菜单/工具栏/功能区

宏/脚本

菜单/工具栏

功能区/Ribbon

图表/图形/图像/多媒体

图表

图形/图像

音频

视频/动画

DAO/链接表/ADO/ADP

DAO/链接表/ODBC

ADO/RDO

ADP

ActiveX/第三方控件/插件

Treeview树控件

ListView列表控件

Toolbar工具栏控件

微软其它控件

Dbi-Tech

CodeJock

Grid++Report

FastReport

ComponentOne

加载项/插件/Addin

OFFICE集成/导入导出/交互

Excel导入导出/交互

Word导入导出/交互

PPT交互

Outlook控制/邮件

Text文本文件/INI/CSV

PDF/SWF/XML格式

CAD格式

Sharepoint/其它Office

SqlServer/其它数据库

表

视图

存储过程/触发器

函数

用户/权限/安全

调试/维护

SqlServer其它/综合

发布/打包/文档/帮助

开发版/运行时

打包/发布/部署

开发文档/帮助制作

Access完整行业系统

采购管理系统

销售管理系统

仓库管理系统

人力资源管理HRM

CRM管理系统

MRP/ERP管理系统

BRP/流程优化

其它管理系统

心得/经验/绝招
其它/杂项
Excel技巧

Excel应用与操作

Excel开发编程

Word技巧

Word应用与操作

Word开发编程

Outlook技巧

Outlook应用与操作

Outlook开发编程

热门文章

  • 局域网如何获取某一机器的日..
  • Access如何判断字符串..
  • 新手来看:为什么数字计算结..
  • 如何确定某年第N周的第一天..
  • 代码设置ACCESS对象颜..
  • 判断窗体是否打开的两种方法

最新文章

  • Access或VB VBA..
  • 关于VBA的0、""(空字..
  • Access导出函数Out..
  • Access日期与日期区间..
  • RecordSource ..
  • Access子窗体事件控制..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 模块/函数/VBA/API/系统 > VBA基础
VBA基础

用VB轻松调用其他程序

用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


(算法函数_API_系统-相关文章技巧链接):
Access 调用计算器、游戏等一切程序的简单方法
发布人:佚名-Access中国  
分享到:
点击次数:  更新时间:2004-10-29 15:46:35  【打印此页】  【关闭】
上一条:如何将透视中[页1里的项1 项2 ...]改为自己想设定的名字?  下一条:工作表中不能插入行



相关文章

  • • Access或VB VBA判断数组的值是否为空的几种方法
  • • 关于VBA的0、""(空字符串)、Null、Empty、与 Nothing 的区别
  • • Access导出函数OutPutto解释
  • • Access日期与日期区间的筛选
  • • RecordSource SourceObject ControlSource属性的区别
  • • Access子窗体事件控制父窗体
  • • 事件​change和AfterUpdate的区别
  • • 代码修改完善方法示例(初学者必读)

热门文章

  • [2013-10-19] Access中EXIT Sub与End Sub的区别access数据库
  • [2005-08-12] 自定义日期显示函数access数据库
  • [2004-11-28] The Power of CGridMend 1.2access数据库
  • [2013-10-09] access vba几种数字取整的方法access数据库
  • [2003-12-20] 充分利用智能提示功能access数据库
  • [2017-01-06] Access DAO使用书签进行搜索并同步窗体的方法access数据库

热门产品

公司动态|在线留言|在线反馈|友情链接|会员中心|站内搜索|网站地图

中山市天鸣科技发展有限公司 版权所有 1999-2023 粤ICP备10043721号

QQ:18449932

Access应用 Access培训 Access开发 Access平台

access|数据库|access下载|access教程|access视频|access软件

Powered by MetInfo 5.3.12 ©2008-2025  www.metinfo.cn