首页
学习
活动
专区
圈层
工具
发布

VBA解析VBAProject 05——提取模块代码

通过前面的文章能够知道,每一个模块的代码,在VBAProject中也就是一个数据流,这个数据流经过了run length encoding的算法进行压缩。...前面介绍的是自己使用VBA代码来解压缩,其实也有现成的API RtlDecompressBuffer可以使用,具体用法可以网上找找。 所以,只要能找到模块的数据流,然后进行解压缩就可以还原模块的代码。...模块的数据流也就是在复合文档中读取一个数据流,另外要注意的是,这样读取出来的模块数据流并不都是我们写的VBA代码,还需要结合解析dir流时候得到的模块信息进行截取,再进行解压缩: '读取某个模块的代码...'ModuleName 模块的名称 'StrCode 返回模块的代码 'Return 返回出错信息 Function GetModuleCode(ModuleName As String,...[" & ModuleName & "]" Exit Function End If Dim i As Long, j As Long '跳过前面不需要的部分

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

    JavaScript图片库

    注意return false;表示阻止超链接跳转的默认行为;让我们了解一下DOM1中的事件处理函数的工作机制。在给某个元素添加了事件处理函数后,一旦事件发生,相应的JavaScript代码就会被执行。...DOM1中适用;所以这段代码只会在支持DOM1标准的浏览器中才会有效,其他的浏览器任然会被带到目标窗口!...的元素是否存在,如果不存在的话网页任能正常运行 if (document.getElementById("imagegallery")) { var gallery = document.getElementById...的元素是否存在,如果不存在的话网页任能正常运行 if (document.getElementById("imagegallery")) { var gallery = document.getElementById...的元素是否存在,如果不存在的话网页任能正常运行 if (document.getElementById("imagegallery")) { var gallery = document.getElementById

    4.2K60

    VBA使用API_01:读取文件

    VBA用到一定的时候,就会发现有些功能实现不了,被限制束缚了,这个时候一旦接触到了Windows API,就感觉又有了一片新天地。...其实很多系统的操作,像文件的操作等,都是要调用Windows API的,就算是VBA里的文件操作语句: Open pathname For mode [ Access access ] [ lock...2、参数传递 值参数 很多参数API中只是使用,所以VBA里传递是按值传递还是按照地址传递其实都是一样的,这个和VBA里的Function是一样的。...传递了,而数字没有初始的时候是0,API函数去操作指针地址0的时候,必然会出错造成Excel的崩溃。...Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long 'lpBuffer 用来接收从文件中读出的数据的缓冲区指针

    2.1K10

    错误捕获

    在VBA中,运行时错误发生的时候,会直接中断程序的运行,如果仅仅是程序的使用者,可能完全不会代码,那么出现这种中断程序的运行的状况,使用者就会不知所措了。...比如用VBA代码激活一个工作表,但这个工作表不存在的情况下: Worksheets("ErrTest").Activate ? 程序被中断了,不懂VBA的人碰上这个肯定就不知道如何去处理了。...1、On Error语句: 在VBA里处理错误使用的是On Error语句: Sub TestErr() '出错的时候,程序跳转到标签ErrTest处 On Error GoTo ErrTest...: Function HasSht2(sht_name As String) As Boolean On Error Resume Next '尝试激活工作表,不存在的工作表情况下会出错...因为作为写程序的人,必须要考虑到使用者的情况,给使用者出现运行时错误是不应该的,所以写程序的过程中,一定要非常严谨,尽量在所有的程序中都加上错误捕获的代码。

    3.6K10

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

    尝试访问不存在的数组元素是一个常见的示例。例如: Dim MyArray(100) As Single … MyArray(150) = 1.2 ‘导致错误!...良好的编程习惯可以帮助防止由代码引起的错误,但是某些错误显然是程序员无法控制的。这是VBA程序应始终包含错误处理的原因之一。 错误和Excel对象模型 某些Excel对象内置了自己的错误处理。...一个示例是Workbook对象,如果尝试打开磁盘上不存在的工作簿,或者尝试将工作簿保存到不存在的磁盘上,则Workbook对象会捕获错误并显示其自己的对话框(如图26-2所示))。...image.png 图26-2:一些Excel对象在内部处理错误并显示自已的对话框 避免错误 有一些好的编程习惯可以帮助避免程序中的错误,这些类似于第24课中建议的防止错误的实践,但是值得重复: 总是使用...延迟错误处理 另一种错误处理技术是延迟对错误的处理。换句话说,VBA不会捕获错误,而是将其忽略。然后,你的代码可以检查Err对象,以查看是否发生的错误类型。

    9.8K30

    Excel VBA对象模型

    1、对象模型 上一讲说了Range对象,这一次我们从总体方面来说一下Excel VBA的对象模型。 你真正想了解Excel VBA里的对象的话,看官方文档是最好的,没有比官方文档更准确的了。...Range("A1").Value看看,出错了吧,为什么呢? 这个时候最好自己先好好想一下,然后看看那个错误的提示框上什么意思,多想想。 ? 对象定义错误:为什么会有这个错误?...Range("A1"),因为这个Range对象根本不存在,我们通过ThisWorkBook.Close False这句代码,已经关闭了工作簿,当前根本没有了单元格了,操作根本不存在的东西,当然出错。...我以自己非专业的认识讲一下,可能有不对的地方: 你双击一个Excel文件 windows操作系统根据后缀找到注册表里对应文件后缀的可执行文件,也就是EXCEL.EXE EXCEL.EXE首先运行起来...然后EXCEL.EXE读取那个文件在硬盘上的数据,并解析数据放到了内存中 解析过程也就是去创建1个树形的对象模型 解析过程会根据文件的情况创建Workbook、Worksheet对象,其实所谓的创建也只是在内存中按一些规则来组织数据

    3.2K32

    如何确保安装并加载VBA加载项文件

    标签:VBA 在某些情形下,可能希望将加载项中的代码合并到其他VBA过程中,或者允许其他人访问你的加载项。...此时,为了防止加载项卸载或未安装而导致出错,可以使用VBA代码确保加载项正确加载到你正在使用的任一Microsoft Office程序中。...VBA代码如下(注:代码来源于www.thespreadsheetguru.com,供参考): Sub InstallCheckAddIn() '目的:如果当前没有安装则从加载项文件夹中装载加载项...TestAddin = Workbooks(AddIns(AddInName).Name) StoreError = Err On Error GoTo 0 '如果没安装加载项, 在加载项文件夹中查找并装载...MsgBox "没要找到要安装的加载项: " & AddInName End If ExitSub: End Sub 注意,上面的代码仅在系统默认的加载项文件夹中搜索你想要的加载项,如果你在自己的文件夹中存储加载项

    80550

    VBA新手教程:从入门到放弃(0)

    于是本着玩的心态,开了个店。很快第一单就上门了: 词频统计: A列是关键词的组合,关键词之间以空格连接。 在B列竖向输出A列所有的关键词,去重。 C列输出对应B列关键词的出现频率。...后来在某鱼还遇到了很多好玩的事儿: 某大叔嫌之前人写的自动打印不智能不能批量找我加; 一个主要工作就是填表的小妹妹因为跨表总出错让我帮忙做检查功能; 工厂大叔因为技术离职了VBA没人维护找我修改之前我没接触的功能...; 一个小哥让我写彩票统计工具还问我“你们大学生有文化能不能帮我分析一下彩票到底能不能赚钱”; 一个已经用python把微博数据爬到excel中但是不会处理的神奇小哥; 一堆给我提英文需求让我帮忙做作业的海外留学生...,所以当我游走在这繁杂的都市中,此刻想到的…… ---- 你也一定有写VBA的需求!...检查上方菜单栏,如果有“开发工具”,跳过此步骤;如果没有,则点击文件,选项,自定义功能区,将右侧的“开发工具”勾选。(放心,以后不会再让你设置了) ? ?

    1.5K30

    编写可维护代码3:适当的抛出错误提示

    在js开发中,调试错误是一个比较头疼的事,又不像java的debug那么方便,定位错误往往不是那么容易,除非对代码熟悉无比,但即使是自己写的代码,功能一复杂,时间一长,再想快速定位问题,至少我现在是比较头疼的...js中抛出错误的方法有两种:throw new Error()抛出错误和try...catch..捕获错误。...先来看throw new Error(): function getDiv(el){ if(el && el.getElementsByTagName){ return el.getElementsByTagName...当以这种方式抛出错误时,如果没有经try-catch语句来捕获的话,浏览器通常直接在控制台显示错误消息字符串。 通常在抛出的错误提示字符串中,应尽量写清错误目标和原因。...:期望的对象不存在时抛出,如试图在一个null对象引用上调用一个函数。

    1.6K50

    DOM 节点遍历:掌握遍历 XML文档结构和内容的技巧

    CDATA 部分中的所有内容都会被解析器忽略。CDATA 部分以 "以 "]]>" 结束:元素的值在 DOM 中,一切都是节点。元素节点没有文本值。元素节点的文本值存储在子节点中,这个节点被称为文本节点。要更改元素的文本值,必须更改元素的文本节点的值。...与元素节点不同,属性节点具有文本值。更改属性值的方式是更改其文本值。使用 setAttribute() 更改属性setAttribute() 方法更改属性的值。如果属性不存在,则会创建一个新属性。...此代码将从加载的 xml 中删除第一个 元素:y = xmlDoc.getElementsByTagName("book")[0];xmlDoc.documentElement.removeChild...示例: removeAttribute('category')此代码将删除第一个 元素中的 "category" 属性:x = xmlDoc.getElementsByTagName("book

    1.7K10
    领券