首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Excel编程周末速成班第26课:处理运行时错误

在程序运行时发生的程序错误称为运行时错误,重要的是要理解运行时错误(或只是错误)与在VBA程序中可能发生的其他两类问题之间的区别: bug是程序逻辑中的缺陷,会导致程序产生不正确的结果。...当发生错误并且程序不包含处理错误的代码时,程序将停止并显示一个对话框,其中包含错误说明,如图26-1所示。通常无法从未处理的错误中恢复,这就是为什么它们如此讨厌的原因。...image.png 图26-1:VBA通过显示此对话框来发出未处理的错误信号 你会看到错误对话框提供了错误的简要说明以及错误号。每个VBA错误都有其自己的错误编号。...良好的编程习惯可以帮助防止由代码引起的错误,但是某些错误显然是程序员无法控制的。这是VBA程序应始终包含错误处理的原因之一。 错误和Excel对象模型 某些Excel对象内置了自己的错误处理。...忽略错误 Excel的SpecialCells方法使你能够获得对满足特定条件的区域内的单元格的引用,例如包含公式的单元格或包含批注的单元格。如果找不到匹配的单元格,则会产生错误。

6.8K30

VBA: 隐藏模块中出现编译错误:的解决对策

文章背景: 最近发现有些办公电脑打开一些excel文件(xls格式)时,会弹出一个对话框,显示""隐藏模块中出现编译错误:"。...通过64位office软件打开早期的excel文件,如果代码中存在早期面向32位office编写的VBA代码,可能会存在上述的编译错误。...1 此错误的原因和解决方案 此错误的原因: 当受保护(隐藏)的模块内的 VBA 代码中存在编译错误时会引发此错误。由于模块是受保护状态,因此不会公开具体的编译错误。...3 VBA工程密码破解 当受保护(隐藏)的模块内的 VBA 代码中存在编译错误时,由于模块是受保护状态,因此不会公开具体的编译错误。此时,需要取消对该模块的保护。...参考资料: [1] 隐藏模块中出现编译错误:(https://docs.microsoft.com/zh-cn/office/vba/language/reference/user-interface-help

14K11
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Excel编程周末速成班第24课:调试和发布应用程序

    由于实际上存在无限数量的潜在bug,因此无法列出或描述Excel程序中可能出现的错误。以这种方式思考——程序应该做的任何事情都可能做错。 虽然VBA会向你报告错误,但没有对于bug的处理机制。...如果尝试使用未声明的变量,则VBA会显示一条错误消息。这样可以防止漏掉拼写错误的变量名。如果没有OptionExplicit,则仅将拼写错误的变量名视为新变量,并且结果很可能是bug。...VisualBasic在“监视”窗口中显示表达式值(定义监视表达式时,此窗口会自动打开)。每当程序进入中断模式时,显示的值都会更新。 可以指定每当表达式的值更改时,程序就进入中断模式。...对于其他情况,例如可在Web上常规下载的共享软件应用程序或将在整个大型多办公室组织中发布的应用程序,情况可能会变得更加复杂。例如,要使用Excel应用程序,你必须安装Excel或者Excel查看器。...要点回顾 本课程向你展示了如何使用VBA的调试工具,并探讨了发布Excel应用程序时涉及的因素。 程序bug是使程序无法正确运行的代码错误。

    5.8K10

    从VBA到Python,Excel工作效率如何提高?

    作者:Costas 编译:1+1=6 1 前言 如果有一种方法可以将Excel与Python集成起来,该多好啊!...现在有了: xlwings库允许我们通过VBA调用Python脚本来进行两者的交互! ? 2 为什么要将Python与Excel VBA集成? 事实上,你可以在VBA中做任何事情。...那么为什么要使用Python呢?原因有很多: 1、你可以在Excel中创建一个自定义函数,而不需要学习VBA。 2、使用Python可以显著加快数据操作的速度。...上,人们经常会看到以下错误: ?...打开.xlsm文件,你会立即注意到一个名为_xlwings.conf的新Excel工作表。如果你希望覆盖xlwings的默认设置,只需重命名该工作表并删除开始的下划线即可。

    11.3K20

    《Python for Excel》读书笔记连载2:为什么为Excel选择Python?(续)

    这样可以更容易地发现错误并继续维护代码。这就是为什么Python之禅中有一行是“可读性很重要”。...例如,Excel2016增加了自动化PowerQuery的支持。一种在二十多年前就停止发展的语言正在失去过去几年在所有主要编程语言中引入的现代语言概念。例如,VBA中的错误处理确实显示了它的时代。...如果你希望在VBA中优雅地处理错误,它是这样的: Sub PrintReciprocal(number As Variant) '如果number是0或字符串,则会产生错误 On Error...Resume Finally End Sub VBA错误处理涉及使用标签,如示例中的Finally和ErrorHandler。...通过学习如何将Excel与Python相结合,你可以在这两个方面都获得优势,并通过自动化节省时间,且因为遵循编程最佳实践更容易而犯更少的错误,此外,如果需要,将能够在Excel之外扩展应用程序。

    2.6K10

    打破Excel与Python的隔阂,xlwings最佳实践

    从步骤上来说: 定义 Python 自定义函数(在文件 myproject.py 中) 点击"导入函数"的按钮(在 Excel 文件 myproject.xlsm 中) 那么为什么需要点击 "导入函数"...首先,我们之所以能在 Excel 上输入公式时,出现我们的自定义函数,是因为在这个 Excel 文件中,存在 vba 代码,定义了同名的方法: 从 vbe 界面中可以看到,当我们点击"导入函数"按钮时...通过快捷键 alt + F11 即可打开 因此,Excel 公式执行时,会转而执行 Python 文件中的同名函数。...Python 文件,在 Excel 上无须点击"导入函数"按钮,只要公式有刷新(比如修改公式引用到的单元格的值),就能看到最新结果: 只有10行结果 你可能会觉得每次修改都点一下导入按钮,万无一失。...这问题由于 xlwings 在执行 vba 的方法时,会启动一个 Python 进程(只有首次运行的时候),然后加载 myproject.py 中的代码。但他没有设置启动目录。

    5.5K50

    Excel VBA对象模型

    1、对象模型 上一讲说了Range对象,这一次我们从总体方面来说一下Excel VBA的对象模型。 你真正想了解Excel VBA里的对象的话,看官方文档是最好的,没有比官方文档更准确的了。...这样你关闭了那个唯一打开的Excel文件,但是这时候,Excel这个程序并没有退出,你还可以看到1个界面,这个就是我们安装目录里,那个叫做EXCEL.EXE(我们双击打开这个,会自动创建1个新的工作簿)...Range("A1").Value看看,出错了吧,为什么呢? 这个时候最好自己先好好想一下,然后看看那个错误的提示框上什么意思,多想想。 ? 对象定义错误:为什么会有这个错误?...天子觉得这样管理太累,自然就要分封了,他分封一个国,在VBA里我们可以这样新建1个Workbook,在立即窗口输入: Application.Workbooks.Add 这时候你能看到,出现了一个空白的工作簿...4、小结 Excel VBA对象模型,和自己平时操作联系到一起,你能操作什么,就能找到对应的VBA对象。 然后就是多去用才能熟悉。

    2.3K32

    用户窗体示例:工作表数据与用户窗体的交互

    标签:VBA,用户窗体 好的网站是非常优秀的学习资源,认真研究其分享的知识是我们快速提高水平的方法之一。...这个示例仍然来自于thesmallman.com,演示了用户窗体如何与工作表中的数据进行交互:如何使用Excel工作表中的数据填充用户窗体,并将编辑后的数据发送回工作表;并且在这个例中,只需在用户窗体中输入一个关键字...这听起来很合乎逻辑,但你会惊讶地发现,很少有用户窗体是用这种简单的逻辑来设置的。不知道为什么! 在这个示例中,我们会添加一些非常简洁的逻辑。...如果找不到该注册号,将显示错误消息。 编辑用户窗体后,有一个“更新”按钮。单击此按钮,会将数据发送回包含数据的工作表,并使用你所做的任何更改对其进行更新。...如有兴趣的朋友,可以直接到该网站下载原始示例工作簿,或者到知识星球App完美Excel社群下载中文示例工作簿。

    1.4K20

    这些掌握了,你才敢说自己懂VBA

    上周,我发了关于Excel VBA的第一篇文章后,社群里就砸开了锅 看到辣么多小伙伴们,辣么喜欢,我的干劲儿就更足了。...于是,我准备把Excel VBA写成一个系列免费教程,撸完这个系列你也是VBA界的黑山老妖了。...不错,用公式确实能够实现上述案例的结果,但是,VBA拥有公式无可比拟的优越性: 第一,公式无法使用「按钮控件」; 第二,日常的工作场景一般会涉及加减乘除等综合运算,如果我们使用公式就会格外的复杂而难以控制...弹窗提示「编译错误」 b. 出错的内容自动变为红色 c. 以「蓝色」模糊定位到出错的位置 出错的主要原因是我们采用了“人类语言”,而不是计算机能够识别的语言,Excel只能识别VBA的语法。...(12)保存代码 点击右上方「保存」,VBA弹窗出现提示,我们点击「否」,在「保存类型」中选择「Excel启用宏的工作簿(*.xlsm)」 要点注意: a.文件报错为「.xlsm」,而不是「.xlsx

    47930

    ExcelVBA从入门到精通——(1)实现第一个VBA程序

    VBA简介&用途 Visual Basic for Applications(VBA),是依附在应用程序(例如Excel)中的VB语言。...只要你安装了Office Excel就自动默认安装了VBA,同样Word和PowerPoint也能调用VBA对软件进行二次开发而让一些特别复杂的操作“脚本化”。...选择最方便的即可 1、F5执行 2、按执行按钮 3、运行——运行子过程 一点小建议——使用“立即窗口” 如果你用过Rstudio写R代码或者Spyder写Python代码的话,“立即窗口”类似于控制台,能提示代码编译错误和进行实时计算...1、打开“立即窗口” 视图——立即窗口 2、在立即窗口输入代码直接作用于excel 选中一个单元格,然后在立即窗口输入代码(不必定义Sub过程),敲击回车键执行: 可以看到执行后被选中的单元格出现了你的昵称...写在最后 后续我会详细介绍VBA的语法、函数和数据处理,帮助零基础的朋友实现从VBA入门到精通(精通估计是开玩笑的,能熟练使用VBA完成日常繁琐Excel操作“脚本化”应该是我们的目标。

    2.6K10

    这些掌握了,你才敢说自己懂VBA

    于是,我准备把Excel VBA写成一个系列免费教程,撸完这个系列你也是VBA界的黑山老妖了。...不错,用公式确实能够实现上述案例的结果,但是,VBA拥有公式无可比拟的优越性: 第一,公式无法使用「按钮控件」; 第二,日常的工作场景一般会涉及加减乘除等综合运算,如果我们使用公式就会格外的复杂而难以控制...弹窗提示「编译错误」 b. 出错的内容自动变为红色 c. ...以「蓝色」模糊定位到出错的位置 image.png 出错的主要原因是我们采用了“人类语言”,而不是计算机能够识别的语言,Excel只能识别VBA的语法。 那么,VBA语法是什么呢?...image.png (12)保存代码 点击右上方「保存」,VBA弹窗出现提示,我们点击「否」,在「保存类型」中选择「Excel启用宏的工作簿(*.xlsm)」 image.png image.png

    3.8K01

    Python让Excel飞起来:使用Python xlwings实现Excel自动化

    图2 现在,Excel功能区中将出现一个名为“xlwings”的选项卡,如下图3所示。 图3 至此,设置已完成,我们可以使用用Python自动化Excel了!...要说明的是,在某些情况下,可能会弹出“Automatio error 440”错误消息提示,则需要进行一些设置。...图13 然后,到VBA编辑器中,设置对“xlwings”的引用,如上文中图10所示。 调试 刚开始可能会遇到的两个常见错误是: 1.“Automatio error 440”(自动化错误404)。...上文中已讨论了如何修复此错误,确保Excel宏设置正确。 2.键入用户定义的函数时,单元格中会显示“Object Require”(对象要求)。...确保在VBA编辑器菜单“工具->引用”中选取了“xlwings”,并将更改保存到相应的Excel文件中。有时,当打开多个Excel工作表时,我们可能会无意中将此更改应用于另一个文件。

    9.7K41

    从VBA的vbNullString认识API参数传递

    最近在写个简单的程序时,用到了API FindWindow,复制声明后,直接就把代码写了,可是发现一直找不到窗口,代码: Sub testFindWindow() Dim str As String...这又是为什么呢! 这里只能进行猜测了,VBA在比较2个字符串的时候,可能是先读取长度,如果都为0,则判断为相同了,""和vbNullString在使用LEN函数的时候,返回的都是0。...API String类型参数传递 从帮助文件中知道,vbNullString 值为 0 的字符串,如果真的传递0过去,很明显也是不行的,数据类型就不对,所以这个只是一个标志,VBA编译器会具体去处理这种情况...VBA会帮使用者将VBA的String类型首先从Unicode转换为ANSI编码,然后取出转换后的Char数组的第一个地址,再将这个地址传递给了API,API如果有返回值,VBA就会做一个相反的操作,测试代码...而在FindWindow里,VBA编译器自动为使用者做了处理,所以我们在使用API的时候,根本就不需要关注这个。这也容易造成VBA使用者不清楚原理,出现错误的时候很难找到具体的原因。

    1.8K10

    【内卷到底】Excel催化剂免费提供VBA解密功能,除打开密码外,其余所有密码均可秒级破解

    VBA密码破解,在一般地插件里,都是收费方式提供,Excel催化剂,全功能免费,最新推出VBA解密功能,还要公开核心源代码,这免费程度够诚意了么?...密码相关的历史推文: 第26波-正确的Excel密码管理之道 第123波-批量创建或取消Excel文件打开密码 Excel催化剂开源第18波-工作表、工作薄保护破解 功能展示 使用方法很简单,点击菜单后...中途会跳出这个错误弹窗,选择是即可,原因是破解后的文件用代码来打开,不能屏蔽此错误,手动选择【是】后,程序另存为文件后,再手动打开文件就不报错了。...VBA工程密码破解分享,同步推荐两款VBA代码助手工具 核心代码为:445042改为444278 var binPath = Path.Combine(tmpDir, @"xl\...当然,如果纯粹操作Excel等OFFICE对象来说,简单的套几个循环、选择结构,把录制宏的代码串起来一下,还是可行的。

    2.8K80

    Active APT

    此恶意代码包以 VBScript 开始,如果 Outlook 进程正在运行,该脚本首先会杀死它,然后通过更改注册表值来消除 Outlook 中 VBA 宏执行的安全性。...值得注意的是,有两个文本文件,一个用于 Word,一个用于 Excel,包含要插入目标文档的恶意宏的 VBA 源代码,以及负责查找和破坏现有文档的 .NET 程序集。...image.png 编译器模块中包含的部分 C# 下载器源代码 GitHub项目模块 如图 7 所示,此 .NET 可执行文件使用 GitHub 存储库来获取和执行下载程序。...一些 C# 编译器模块示例中包含的源代码中留下了注释,或者 Outlook VBA 模块生成的电子邮件中的俄语编码错误,这表明在发布和使用它们的许多工具之前没有进行严格的审查或测试在野外。...然而,虽然这些错误可能会降低他们工具的整体效率,但该组的快速执行和适应也有一些优势。攻击的数量和无情可能会在其目标中造成持续的恐惧状态。

    8K00

    Excel VBA解读(163):错误处理技术之概述

    学习Excel技术,关注微信公众号: Excelperfect 在VBA代码中,我们经常会看到类似于On Error Resume Next这样的语句,这是编译器在代码遇到错误时自动处理的语句。...VBA的错误类型 在VBA中,有3类错误: 1.语法错误 2.编译错误 3.运行时错误 使用错误处理来处理运行时错误。...语法错误 当一行代码输入完成后按下回车键时,VBA会评估其语法是否正确,如果不正确,将显示一条错误消息。 例如,在输入If语句时忘记了Then,VBA将显示下图1所示的错误消息。 ?...图2 在编写代码时,我们可以经常运行菜单栏中的“调试—编译”命令,及早发现编译错误。如果菜单“调试”下的“编译”命令为灰色,表明代码不存在编译错误。 运行时错误 程序运行时会发生运行时错误。...如果选取“发生错误则中断”选项,那么VBA会忽略错误处理代码。 ? 图3

    3.9K10

    Excel插件-多工作薄合并工具之安装注意事项和下载地址公布

    安装步骤 因插件是使用visualstudio的开发环境开发的,这种Excel插件有别于传统的使用VBA语言开发的Excel插件,需要对用户电脑有一些底层的运行环境的要求。...最最突出的是此种VSTO方式开发的插件是Excel文档和实现功能的代码可以分离,对插件维护、升级、错误修复等等一些开发过程中不可避免的问题时,使用VSTO的数据和代码分离技术,数据保存在用户电脑,代码开发者开发好重新发布...,用户可以无需担心升级、错误修复等原因而不得不把手头的Excel文件弃用,重新获取开发者最新的版本的Excel文件,然后再重头再来完成之前在前一版本里已经个性化做过的事情。...有机会再给大家演示这种自动升级的技术部分,今天所分享的部分还是需要有更改重新覆盖,但这种覆盖也只需覆盖代码文件(dll后缀的文件,Excel工作薄还是可以保留使用,无需更换) 安装底层组件 此组件因不同的终端电脑环境不同...双击后出现一个安装提示,点击【安装】即可 ?

    85120

    Excel是世界上最危险的软件?

    你在Excel中犯下的错误会造成多大的损失? 顶级投行摩根大通用惨痛的教训给出了答案:62亿美元! 事情是这样的。...而正是这个模型,让它出现了震惊金融界的巨额亏损。 令人唏嘘的是,摩根大通在事后的调查报告中提到,这个模型的问题竟然和Excel有关: 这个模型用到一系列Excel工作表。...事后调查发现,该模型不仅并未被自动化,还存在其他一些严重错误,比如在Excel工作表中本应该除以平均数,却除以了总和。这些错误导致该模型严重低估了投资组合的实际亏损风险。...“伦敦鲸事件”是最骇人听闻的Excel事故之一。至于为什么说是“之一”,感兴趣的朋友可以搜索“Excel Horror Stories”。...我会告诉你为什么把Python 用到Excel 上是明智之举,它和Excel 内置的自动化语言VBA 相比又有什么优势。 这本书适合我吗?

    74420

    从 Excel 数据分析到 PowerBI 其实是自然之选

    然后发现很多业务数据会以某种规律化的方式反复出现,便专门用表结构来组织这些数据,并强行要求这些数据必须满足某些规则,否则会被视为是脏数据(不符合要求的业务数据),当然这种工作也可能由一个专门的部门IT部来完成...做大量业务分析的伙伴希望更好的提升效率,包括Excel的发明者微软公司也面临同样问题,这就出现了数据模型的概念,期初数据模型由专业的IT人员设计,由终端用户使用,而在现如今的Excel中,人们可以自行设计数据模型...例如一旦你在产品表中插入了一列,那 VLOOKUP( [@产品ID], 产品, 3, FALSE ) 可能将导致计算到另外的列,而这种并非会报错,有时这种错误很难发现,导致很严重的业务计算错误。...但依然会遇到问题,就是无法从产品角度进行分析,但仔细观察,会发现: 原来透视表知道我们可能找不到需要的字段,因此给了一个机会让此时可以从更多表格来重新选择。...如果您仔细留意,这里根本没提VBA,因为 VBA 就不是为了分析数据而生的,它虽然强大,但它不是用来分析数据的。

    2K11
    领券