news 2026/4/23 13:52:16

【Excel VBA编程】共享对象状态——多个变量引用同一对象

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Excel VBA编程】共享对象状态——多个变量引用同一对象

VBA中的普通数据类型(如Integer、String)是值类型,赋值时会创建副本。而对象变量是引用类型,赋值时传递的是引用。理解并善用这一特性,是编写高效、模块化VBA代码的关键

那么要如何理解这一特性呢?接下来给大家举几个例子

示例1

一个最直接、也是平时常用却从未正视过的例子:让两个Range对象变量rng1和rng2都指向Sheet1工作表中的C2单元格。rng1变量修改C2单元格内容,rng2变量修改C2单元格显示样式(如字体加粗、改变单元格底色等)

Dim rng1 As RangeDim rng2 As RangeSet rng1 = Worksheets("Sheet1").Range("C2")Set rng2 = rng1' rng1 修改单元格内容rng1.Value = "Rng1变量"' rng2 修改单元格的格式rng2.Font.Bold = Truerng2.Interior.Color = vbYellow

执行以上代码后,可以看到C2单元格变化

其原理:rng1和rng2都指向同一个Range对象。因此,无论是通过rng1还是rng2来改变单元格的值或格式,效果都是相同的,因为它们操作的是内存中的同一个对象实例

友情提示:给对象变量赋值时,必须使用Set语句,如Set rng2 = rng1。如果省略Set,VBA会尝试进行值赋值,从而导致“运行时错误91:对象变量或With块变量未设置”

示例2

当需要将一个对象(如数据字典)传递给另一个过程或函数进行处理时,除了通过之前讲过的参数传递外,还可以使用Set语句直接赋值给另一个对象变量,使多个变量引用同一个对象实例

示例代码如下:

  • 模块最上方定义全局对象变量globalDict

  • 主程序MainPro创建字典对象,并向字典中添加了一个元素Key1对应的内容是“Value1”

  • 子程序SubProcess通过Set语句让变量UpdateDict指向字典并修改字典内数据

Public globalDict As ObjectSub MainPro()Set globalDict = CreateObject("Scripting.Dictionary")' 向字典添加数据globalDict.Add "Key1", "Value1"Debug.Print "MainPro中Key1:" & globalDict("Key1")' 调用子过程Call SubProcessSet globalDict = NothingEnd SubSub SubProcess()Dim UpdateDict As ObjectSet UpdateDict = globalDictIf Not UpdateDict Is Nothing Then' 修改字典内容UpdateDict("Key1") = "Updated Value"' 遍历字典Dim key As VariantFor Each key In UpdateDict.KeysDebug.Print "SubProcess中" & key & ": " & UpdateDict(key)Next keyEnd IfSet UpdateDict = NothingEnd Sub

其中,全局变量globalDict指向一个字典对象。在子过程中通过`Set UpdateDict= globalDict`语句,让变量UpdateDict也指向了同一个字典对象。对UpdateDict的任何修改都会直接作用于该字典

此时,可能有朋友就疑惑了,既然都定义了全局变量,全部使用全局变量不行吗?还要再通过set语句让多个临时变量引用,有那个必要吗?

其实,在VBA编程中,虽然直接使用全局变量确实是一种简洁的方法,但通过Set语句让多个变量引用同一个对象仍然具有重要的实用价值,这并非多此一举

例如,当我们阅读代码时,看到局部变量名,如UpdateDict,能立即理解该变量在当前过程中的用途,而不需要追溯全局变量的定义。这种“自文档化”的代码风格显著提高了可读性。当然好处不仅仅是这一条,还体现在代码维护、复用、调试等方面,随着代码量输出,相信大家有更深刻地体会

结束语

以上提到的都是对象变量引用,那么,VBA有没有为普通数据类型(如 Integer、String)提供一些机制,让这些值类型的数据也能实现类似“引用”的效果呢?

感兴趣的小伙伴可以持续关注,等待后续的分享哦

本公众号一直在不间断地分享免费的编程案例和实用技巧。无论您是用来提升自动化办公效率还是想提升自我,请关注我的公众号“努力鸭是黑色的”,解锁更多的编程知识

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/23 12:13:42

SaaS建站与独立CMS的深度对比:2026年如何为您的企业选择最佳建站路径

在当前的数字化浪潮中,无论企业规模大小,拥有一个功能完善、形象专业的网站已成为业务发展的基石。然而,面对众多的建站方式,许多决策者会在“便捷的SaaS建站”与“功能强大的独立CMS”之间犹豫不决。本文将从技术、控制权和长远发…

作者头像 李华
网站建设 2026/4/23 13:45:06

《无人驾驶车辆模型预测控制》第四章基于运动学模型和MPC模型预测控制的轨迹跟踪控制CarSim_Simulink联合仿真模型

《无人驾驶车辆模型预测控制》第四章基于运动学模型和MPC模型预测控制的轨迹跟踪控制CarSim/Simulink联合仿真模型 已针对原书及代码中的错误进行勘误,该联合仿真模型可完美复现圆形 在学习龚建伟教授等所著《无人驾驶车辆模型预测控制》一书时,第四章“…

作者头像 李华
网站建设 2026/4/23 13:43:29

XDMA丢包问题分析

目录 简介 外围系统检查 FPGAdebug 主机内存对齐 总结 简介 由于XDMA是黑盒,所以经常有时候排查问题回到瓶颈,那么我们如何去系统的分析,以及解决这些问题呢? 外围系统检查 检查驱动与系统日志:在Linux下&#x…

作者头像 李华
网站建设 2026/4/23 13:35:22

C++函数进阶:默认参数与函数重载,让你的代码更智能!

C函数进阶:默认参数与函数重载,让你的代码更智能! 大家好!今天我们来聊聊C中两个非常实用的特性:默认参数和函数重载。这两个特性能让我们的代码更灵活、更简洁,提高开发效率。 一、默认参数:让…

作者头像 李华