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在程序中如何打..
  • 在Access中获取本机I..
  • 什么是 API?
  • 隐藏Access主窗口之二
  • 删除系统菜单
  • 把EXE文件存入到表的字段..

最新文章

  • Access API函数分..
  • Access VBA 注册..
  • Access Excel ..
  • 毫秒级和纳秒级计时的API..
  • 一种比GetTickCou..
  • VB用PrevInstan..

联系方式

Access交流网(免费Access交流)

QQ:18449932 

网  址:www.access-cn.com

当前位置:首页 > 技巧 > 模块/函数/VBA/API/系统 > API/COM/系统相关
API/COM/系统相关

[技巧分享]多条Shell语句执行导致判断出错的解决办法

问题:
_________________________________________________________________

我在一个模块中的一个过程中写了以下几句代码:
Shell "net use z: \\qmxmaster\D$ "
  Shell "xcopy  w:\bakData     z:\pxsystem\bakData\ /e /c /y", 0
      Shell "net use z: /del"
w:是局域网中A计算机本来就设置的一个网络驱动器,映射B计算机的一个
共享文件夹。z:是通过代码临时在A机器建立的另一个网络驱动器,指向B
计算机的d盘。
          在A计算机运行这个过程,把w:\bakData文件夹中全部文件拷贝到B计算机
(机器名pxmaster) 的D盘 bakData文件夹中。
        现在前两步都做到了,可以建立文件夹并拷贝,但是第3句却不起作用,驱动
器z总是不能消失,可是 我把第3句放到命令行是能够正常执行的。何故?
        是不是考贝时间过长(5-6秒),代码不执行?是否可以让代码执行有一个等待
过程?


解决(tmtony Office中国/Access中国):
_____________________________________________________________
应该是等待时间过长. 两种方法

1.Shell("命令", vbHide, True)  最后参数为true 这个可选参数设为True就可以让Shell执行完才接着Shell下边的代码
2.使用API来判断 建立以下的代码

Option Explicit
'等待shell执行完成后才执行下一条代码
Private Declare Function OpenProcess Lib "kernel32" (ByVal dwDesiredAccess As Long, ByVal bInheritHandle As Long, ByVal dwProcessId As Long) As Long
Private Const PROCESS_QUERY_INFORMATION = &H400
Private Const STATUS_PENDING = &H103
Private Const SYNCHRONIZE = &H100000

Private Const INFINITE = &HFFFFFFFF
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long

'执行Shell命令并等待程序执行完毕 再返回控制权才继续执行下一句代码
Private Sub Command1_Click()

    Dim pId As Long, pHnd As Long    ' 分别声明 Process Id 及 Process Handle 变数
    pId = Shell("http://www.office-cn.net")   ' Shell 传回 Process Id

    pHnd = OpenProcess(SYNCHRONIZE, 0, pId)    ' 取得 Process Handle
    DoEvents  ' doevents
    If pHnd <> 0 Then
        Call WaitForSingleObject(pHnd, INFINITE)    ' 无限等待,直到程序结束
        Call CloseHandle(pHnd)
    End If
    MsgBox "执行完毕 "

End Sub
发布人:Access中国tmtony-Access中国  
分享到:
点击次数:  更新时间:2013-07-04 23:21:38  【打印此页】  【关闭】
上一条:[经验分享]Access中判断表是否存在的通用函数  下一条:[经验技巧]Access中使用微软Treeview树形控件的烦恼



相关文章

  • • Access API函数分享
  • • Access VBA 注册表操作源码
  • • Access Excel VBA程序同时兼容32位和64位的解决办法
  • • 毫秒级和纳秒级计时的API--timeGetTime、GetTickCount、QueryPerformanceCounter
  • • 一种比GetTickCount 和Timer更精确的计时器
  • • VB用PrevInstance和DDE实现禁止多个实例同时打开并传递命令
  • • 获取版本号及判断是否运行版本
  • • API获取网卡地址

热门文章

  • [2003-12-12] API实现的延时函数access数据库
  • [2003-12-20] 如何让你的程序在任务列表隐藏access数据库
  • [2004-11-23] 用代码创建 DSN(SQL Server ODBC)access数据库
  • [2005-06-12] API使用集锦access数据库
  • [2017-05-28] Access Excel VBA程序同时兼容32位和64位的解决办法access数据库
  • [2009-04-17] 不关闭当前数据库COPY当前数据库access数据库

热门产品

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

Access交流网 版权所有 1999-2018 粤ICP备10043721号

QQ:18449932

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

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

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