VBA: 如何停止当前VBA程序(尤其是死循环)的运行,用程序停止其他程序,暂停程序等(未完成)

2023-11-07 02:20

本文主要是介绍VBA: 如何停止当前VBA程序(尤其是死循环)的运行,用程序停止其他程序,暂停程序等(未完成),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

问题1:想马上当前运行的程序(尤其是死循环),改怎么做?

有时候循环写的有问题写成了死循环,或者电脑很卡,运行太慢想提前中止程序的运行,应该怎么办?

以下方法:

  • ESC
  • ALT +BREAK
  • ctrl+alt+delete 进程停止EXCEL,这个会杀掉EXCEL进程。

 

 

问题2:用1个程序控制其他程序的运行呢?

 

  • 因为VBA是单线程程序,一个过程运行时,无法再开始其他程序。 也就是无法用   SendMessage() 这种做法?
  • 虽然一个程序/过程运行中,可以先在过程里写调用其他程序,但也是自动的(事前设计的),无法在运行过程中停止。
  • 思路1:把循环过程的判断条件,本身加合适的判断,写合理,尽量避免需要提前停止。
  • 思路2:把循环过程的判断条件,本身加合适的判断。然后在循环过程中调用其他程序,但是这个是事前要设计好的,运行过程中也无法停止。(两个过程至少要用公共变量传递数据)
  • 思路3(实际不可行):同样是用公共变量传递数据,但是两个程序独立,一个过程运行时,这时希望一个过程改变公共变量,从而停止另外一个过程的运行。----实际做不到,因为VBA单线程同时只能做一件事。!

 

跳出过程,基本上都得用到这个吧 exit sub ( /exit for     /exit do)

  If a = 1 Then
     Exit Sub
  End If

 

Public xSub testloop3()
x = 0Do While i <= 100 And x = 0i = i + 1If i >= 50 ThenCall test3End IfDebug.Print iLoopEnd SubSub test3()x = 1End Sub

 

下面的例子是测试,无法再一个程序运行过程中,用另外一个程序去控制打断它的

Public aSub testloop1()         '这个测试完全无法打断testloop1的循环
a = 0
i = 0
time1 = Time
Debug.Print time1
Do Until i >= 1000 And a = 0i = i + 1If a = 1 ThenExit SubEnd IfRange("a1").Value = iDebug.Print i
Looptime2 = Time - time1    'time  time() now()Debug.Print time1
MsgBox ("ok,花费时间" & time2 & "秒")
End SubSub test2()a = 1
End Sub

 

3 onkey 在主程序里控制?(下面这部分未完成)

 

 

 

 

4 如何可以点击1个按钮开始运行程序,再点击又关闭?(下面这部分未完成)

 

暂停程序的3个思路

  • 暂停  application.wait(now + timevalue("00:00:03"))  和 application.ontime(now + timevalue("00:00:03"))
  • sleep 500
  • 加入断点,然后点F5运行一下不就暂停了吗?
  • stop  不行,程序运行时被挂起了
  • 运行的时候程序是挂起的吧,只能加暂停的代码 才能让你玩
  • do event

 

 

Do Until b = True
  DoEvents
Loop

 

Private Sub CommandButton1_Click()
b = False
UserForm1.Show 0
Do Until b = True
  DoEvents
Loop
MsgBox [a1] & [a2] & [a3] & Chr(10) & "Done!"
End Sub

Private Sub CommandButton2_Click()
[b1:b100] = "123abc"
End Sub

 

需求详细

  • 没有那种,点一下按钮就运行,在点一下就暂停的功能嘛
  • 你的需求得说细点
  • 点一下,是吧一个SUB跑完,还是中间暂停?
  • 再点是重新跑一个sub  还是接着运行?

这篇关于VBA: 如何停止当前VBA程序(尤其是死循环)的运行,用程序停止其他程序,暂停程序等(未完成)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/360619

相关文章

Java获取当前时间String类型和Date类型方式

《Java获取当前时间String类型和Date类型方式》:本文主要介绍Java获取当前时间String类型和Date类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录Java获取当前时间String和Date类型String类型和Date类型输出结果总结Java获取

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

在IntelliJ IDEA中高效运行与调试Spring Boot项目的实战步骤

《在IntelliJIDEA中高效运行与调试SpringBoot项目的实战步骤》本章详解SpringBoot项目导入IntelliJIDEA的流程,教授运行与调试技巧,包括断点设置与变量查看,奠定... 目录引言:为良驹配上好鞍一、为何选择IntelliJ IDEA?二、实战:导入并运行你的第一个项目步骤1

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

python编写朋克风格的天气查询程序

《python编写朋克风格的天气查询程序》这篇文章主要为大家详细介绍了一个基于Python的桌面应用程序,使用了tkinter库来创建图形用户界面并通过requests库调用Open-MeteoAPI... 目录工具介绍工具使用说明python脚本内容如何运行脚本工具介绍这个天气查询工具是一个基于 Pyt

Ubuntu设置程序开机自启动的操作步骤

《Ubuntu设置程序开机自启动的操作步骤》在部署程序到边缘端时,我们总希望可以通电即启动我们写好的程序,本篇博客用以记录如何在ubuntu开机执行某条命令或者某个可执行程序,需要的朋友可以参考下... 目录1、概述2、图形界面设置3、设置为Systemd服务1、概述测试环境:Ubuntu22.04 带图