2010(2013)Excel VBA中无限循环的控制突破

Posted

技术标签:

【中文标题】2010(2013)Excel VBA中无限循环的控制突破【英文标题】:Control Break out of Infinite Loop In 2010 (2013) Excel VBA 【发布时间】:2014-03-11 08:39:27 【问题描述】:

如果我使用我的新 Excel 编写创建无限循环的代码,Ctrl + Break 将不再起作用。 Esc 键等也没有。

我浏览了整个网络,似乎 Microsoft 有一个错误并且不想修复它。

有没有办法将 Ctrl + Break 功能重新引入 VBA,所以如果将来发生这种情况,我不会失去工作/强制关闭?

【问题讨论】:

【参考方案1】:

Alt + Esc。按住键直到它断开。

从 Windows 7 开始,这将在所有打开的窗口中循环。别介意,继续挤压它。

【讨论】:

如果无限循环包括显示 MessageBox,这将不起作用。 MsgBox 阻止所有输入到 Excel 中。 按住键 10 秒钟,它起作用了 - 我不敢相信。谢谢约翰 这对我不起作用,但是 ctrl + pause break 可以。请务必点击弹出窗口中的“结束”,而不是“调试”。 你救了我的命!!!超级有用的提示,非常感谢!!! 正如一个已经写过的那样:Windows 10 上的 ALT + ESC 在打开的窗口中循环,所以这不起作用【参考方案2】:

至少在 Office 2013 上,Ctrl+Scroll Lock 可以做到这一点。我不需要更改任何设置或启用任何东西。

(公然插件:my blog post 链接到此信息的原始来源:))

【讨论】:

@Colin 当我第一次看到它时,我的反应差不多:)。 即使 Break 位于 Pause 键上,Ctrl+Scroll Lock 仍然有效!【参考方案3】:

减轻这种非常烦人的行为的一种方法是包含

DoEvents

在循环中。不必每次迭代都执行,只要定期调用,Ctrl Break 还是可以的。

注意:我通常在调试代码后将其删除,以避免任何性能影响

【讨论】:

【参考方案4】:

对于那些尝试了之前提出的解决方案但无济于事的人,试试这个。它对我有用(windows8,Excel 2016)

在 VBA 代码窗口上,左键单击并按住(就像您要拖动该窗口一样),同时按住 Alt+ESC 键。它破坏了执行,并问我是要继续,还是调试...我当然选择了调试。

【讨论】:

Windows 10 上的 ALT + ESC 在打开的窗口中循环,所以这不起作用。 虽然 ALT + ESC 在打开的窗口中循环是真的,但它仍然可以有效地打破循环(至少有时) 使用鼠标和alt+esc 可以工作。也许鼠标会停止窗口循环并使用 alt+esc 专注于中断。晚上保护.. 它在 Windows 10 下对我有用,好技巧【参考方案5】:

如果它可以帮助任何人,那么在宏未运行时按 Ctrl+break 仅在您在开发人员之外执行此操作时才有效。

【讨论】:

【参考方案6】:

另一种方法是在循环中故意引入错误。例如说您的循环不应运行超过 1000 次:

Function XYZ()
do while(..)
errcnt = errcnt + 1

if errcnt > 1000 then
  cells.find(what:="Chunk Norris").activate
exit function
endif

loop
end function

它会产生错误并“破坏”代码

【讨论】:

感谢 Alex,这是一种有趣的方式。但我想知道我是否可以像我一样更改 VBA 中的任何命令,例如 Ctrl + Shift + 0,它允许我取消隐藏行。该命令在较新版本的 Excel 中丢失了,但我能够重新引入它。再次感谢! 哈哈好的,您可以在即时窗口(ctrl-G)中查看EnableCancelKey;键入不带双引号的“?Application.EnableCancelKey”,看看它是否返回 0 最好使用debug.assert errcnt <= 1000 来获得这个效果。 Alex- 奇怪的是 application.enablecancelkey = 1,所以这不是问题。我想我将不得不对此不满意,并会接受 Chris 的建议……谢谢各位先生! @Tommyz 不用担心,事实上 Chris 的建议将是我下一步的测试。很高兴有适合您的解决方案!【参考方案7】:

如果您处于设计模式,则在 VBA 编辑器中也无法使用中断 (Ctrl + Break)。在这种情况下,您可以按方形停止图标右侧的设计模式图标。这会将编辑器带回常规模式,然后 break 选项变为可用。

【讨论】:

【参考方案8】:

我可怜的键盘上没有“中断”按钮。我唯一的选择是按 X 关闭程序或 alt+F4。我也必须编写一些代码。

【讨论】:

以上是关于2010(2013)Excel VBA中无限循环的控制突破的主要内容,如果未能解决你的问题,请参考以下文章

EXCEL2010 vba 循环打开某些文件夹下的excel文件

从 Access 2010 VBA 打开 Excel 2010 文件

excel 2010 vba。 sql查询列'like' vlookup

从 Access 2010 VBA 控制 Excel 工作簿

在 Excel VBA 中使用查找的连续循环

Excel 2010 VBA:使用单元格中的值保存文件以确定路径和文件名