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

为什么VBA不让我在用户窗体的命令按钮中声明公共数组?

VBA(Visual Basic for Applications)是一种用于宏编程的编程语言,常用于Microsoft Office套件中的应用程序,如Excel、Word和Access等。在用户窗体的命令按钮中声明公共数组是不被允许的,这是因为VBA的设计理念和语法规则决定了它的作用域和生命周期。

  1. 作用域:VBA中的变量可以具有不同的作用域,包括过程级作用域、模块级作用域和全局作用域。过程级作用域的变量只在特定的过程中可见和使用,模块级作用域的变量在整个模块中可见和使用,而全局作用域的变量在整个应用程序中可见和使用。命令按钮是用户界面的一部分,它通常用于触发特定的操作或事件,因此它的作用域是局部的,只在用户窗体中有效。在命令按钮的事件处理程序中声明的变量只能在该事件处理程序中使用,无法在其他事件处理程序或模块中访问。
  2. 生命周期:VBA中的变量的生命周期取决于其作用域。过程级作用域的变量在过程执行期间存在,当过程执行完毕后,变量将被销毁。模块级作用域的变量在模块加载时创建,当模块被卸载时销毁。全局作用域的变量在应用程序启动时创建,当应用程序关闭时销毁。命令按钮是用户界面的一部分,它的生命周期与用户窗体相关联。当用户窗体关闭时,命令按钮及其事件处理程序也将被销毁,因此在命令按钮中声明的变量无法保持其值和状态。

综上所述,命令按钮是用户界面的一部分,其作用域和生命周期的限制导致在命令按钮中声明公共数组是不被允许的。如果需要在多个事件处理程序或模块中共享数组,可以考虑将数组声明为模块级的或全局的,以确保其作用域和生命周期的适配。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Excel VBA编程

文章目录 如何创建VBA VBA语法规则 声明变量 给变量赋值 让变量存储的数据参与运算 关于声明变量的其他知识 变量的作用域 特殊的变量——数组 声明多维数组 声明动态数组 其他创建数组的方法 数组函数...,作用域为所有模块,即所有模块中的过程都可以使用它,这样的变量称为公共变量 特殊的变量——数组 数组就是同种类型的多个变量的集合 数组中的元素可以通过索引值取出 声明数组时应该声明数组的大小 “public...可以在excel的【功能区】中找到它们 表单控件 控件名称 控件说明 按钮 用于执行宏命令 组合框 提供可选择的多个选项,用户可以选择其中一个项目 复选框 用于选择的控件,可以多项选择 数值调节按钮 通过单击控件的箭头来选择数值...当在工程中添加一个窗体后,就可以在窗体上自由的添加ActiveX控件,只要通过编写VBA代码为这些控件指定功能,就能利用这些控件与excel互动 在工程中添加一个用户窗体 设置属性,改变窗体的外观...在窗体中添加和设置控件的功能 用代码操作自己设计的窗体 显示窗体 手动显示窗体 在VBE窗口中选中窗体,依次执行【运行】——>【运行子过程/窗体】命令,即可显示选中的窗体 在程序中用代码显示窗体 sub

45.7K33

Excel编程周末速成班第18课:使用用户窗体创建自定义对话框

特别是: 用户无法调整窗口大小(尽管可以在VBA代码中调整窗口大小)。 窗口没有最小化和最大化按钮。 窗口没有控制菜单。 然而,用户可以通过拖动其标题栏来移动窗口。...这可以是用户窗体本身或窗体上的控件。 工程窗口在窗体节点下列出了每个工程的所有窗体。 使用“查看代码”和“查看对象”按钮,可以在查看用户窗体的可视界面或其VBA代码编辑窗口之间进行切换。 ?...3.单击该窗体将其激活。然后,在工具箱中,单击“命令按钮”图标。 4.通过在窗体中拖动将按钮放置在所需位置。...该窗体应类似于图18-3。 ? 图18-3:完成的用户窗体 下一步是将所需的代码添加到该窗体。该代码放置在事件过程中,并在用户执行某些操作时自动执行(在这种情况下,单击命令按钮时)。...VBA编辑器提供了一个视觉设计工具,使你可以创建用户窗体的视觉界面。 通过在VBA代码中调用窗体的Show方法向用户显示窗体。 在窗体的代码中,你可以使用Me关键字来引用窗体。

11.1K30
  • 窗体UserForm——代码插入不定数量带事件的控件

    在前面的例子里,我们使用代码插入了不定数量的选项按钮,但是为了激活工作表,还手动插入了一个命令按钮,通过遍历控件的方式,找到要激活的工作表。...在窗体最上面这样写语句的话,就相当于手动插入了一个名称是ob的选项按钮,这样在代码编辑器下拉框里,就能选择ob,然后选择对应的事件。...而窗体的全局变量声明带WithEvents的时候又不能声明为数组控件,所以在窗体里没法插入不定数量,却又带有事件的控件。...这个时候我们就希望如果能使用代码添加事件就好了,可是VBA没有设置这样的接口。 VB.NET这样的语言是有AddHandler 这样的方法去使用代码添加事件的。 那么在VBA里还有没有办法呢?...在窗体中编辑代码: Option Explicit '声明COB数组,记录COB对象 Private cobs() As COB Private Sub UserForm_Initialize()

    1.2K20

    Excel编程周末速成班第21课:一个用户窗体示例

    excelperfect 引言:这是在知识星球App的完美Excel社群中发表的Excel VBA编程系列文章中的一篇,使用一个示例来讲解用户窗体的基础应用。...当然,用户总是可以直接将数据输入到工作表中,那么为什么要为此目的创建程序和用户窗体呢?有以下几个原因: 用户疲劳。...显示“完成”命令按钮,该按钮保存当前数据,保存工作簿并关闭窗体。 显示一个“取消”命令按钮,该命令按钮放弃当前数据并关闭窗体。 验证没有字段留为空白。 验证邮政编码条目是有效的邮政编码。...步骤2:设计窗体 要创建新的空白用户窗体并设置其属性,执行以下操作: 1.按Alt+F11打开VBA编辑器。 2.在工程窗口中,单击标记为VBAProject(Addresses)的条目。...重申一下,这是命令按钮应该执行的操作: “下一步”按钮验证数据。如果验证成功,则将数据输入工作表中,并清除该窗体以输入下一个地址。如果验证失败,则窗体将保留其数据,以便用户可以根据需要进行更正。

    6.1K10

    (ExcelVBA编程入门范例)

    ■ 选择菜单“工具——宏——宏”命令打开宏对话框,若该工作簿中有宏程序,则单击该对话框中的“编辑”按钮即可进行VBE编辑器代码模块,如图00-05所示。...在“工程资源管理器”窗口双击用户窗体图标,会出现相应的用户窗体;在用户窗体图标或者是在用户窗体上单击鼠标右键,然后在弹出的菜单中选择“查看代码”,则会出现用户窗体代码窗口。...图00-08:VBE编辑器窗口(带有用户窗体) 在VBE编辑器中输入VBA代码 如前所述,您可以选择VBE菜单“插入——用户窗体/模块/类模块”来插入模块或用户窗体以及相应的代码窗口。...此外,您也可以在“工程资源管理器”中单击鼠标右键,从弹出的菜单中选择“插入——用户窗体/模块/类模块”来实现上面的操作。在获取相应的代码模块窗口后,就可以输入VBA代码了。...调试VBA代码 在VBE编辑器的菜单中,有两项与调试运行有关的菜单项,即“调试”菜单和“运行”菜单,它们提供了各种调试和运行的手段。在我现阶段进行代码调试时,常用到的有以下几个: ■ 逐语句。

    4.2K20

    Excel用户窗体中添加最小化按钮及窗体最小化的代码实现

    文章背景:用户窗体是Excel中的UserForm对象。在使用UserForm时,曾经目前遇到过两个问题。...新建UserForm窗体时,默认是没有最大化和最小化按钮的,只有一个关闭按钮。 在某个按钮的任务执行完毕后,希望用户窗体可以自动最小化,省去手动点击最小化按钮的麻烦。...在网上搜索一番后,找到了解决上述这两个问题的相关代码。接下来对此进行介绍。我的电脑环境:win10,64位;office 2016。 UserForm中添加最大化、最小化按钮。...运行UserForm窗体,得到如下结果: 可以看到,此时UserForm1中有了最大化和最小化按钮。 最小化用户窗体的代码实现 以一个简单的命令按钮为例。...参考资料: VBA窗体最大化最小化按钮实现(https://ddz.red/uiOTy) 在VBA代码中最小化当前窗体(https://ddz.red/Ku7ey)

    2.5K20

    VBA专题05-1:一文彻底掌握用户窗体编程基础知识(上)

    在Windows对话框中所看到的大多数控件都能在用户窗体中实现,例如命令按钮、选项按钮、复选框、文本框、组合框,以及一些其它不常用的控件如图像、日历,等等。...然后,在代码模块窗口中,对用户窗体或控件添加相应的事件程序代码。 5.显示用户窗体。打开用户窗体模块,按F5键可以运行宏程序,或者单击工具栏中的运行按钮,将显示用户窗体。...同样的方法对在用户窗体模块中所声明的公共变量也是有效的——这是用户窗体的基本属性(例如,frmImputs.AllDone)。注意,不能在用户窗体的代码模块中声明全局变量。...如果要使用代码显示和隐藏用户窗体(例如,可能想在frmIntro窗体中使用一个命令按钮来隐藏frmIntro窗体并显示frmMain窗体),应该使用Show方法(显示窗体)和Hide方法(隐藏窗体)。...用户窗体和控件的事件 事件允许用户窗体和控件对用户所做的操作做出相应的反应。可能熟悉Excel VBA事件,例如Workbook_Open事件、Worksheet_Change事件,等等。

    6.5K20

    VBA中最强大的命令:Evaluate

    标签:VBA,Evaluate 可能很少有人注意到Evaluate命令,也很少被使用,然而,它非常强大且有用。...还有一个“秘密”就是,也可以在定义的单元格区域名称中使用EVALUATE,因此有一些方法可以在不使用VBA的情况下访问单元格公式中EVALUATE的功能。...它包含工作表单元格的所有功能,而“该单元格”包含在VBA命令中。事实上,它甚至可以做单元格不能做的事:可以返回整个数组。...Evaluate允许处理公式: '行为类似单元格的用户窗体文本框 '允许一个文本框里包含另一个文本框要用的公式 Private Sub TextBox1_Change() On Error Resume...'这似乎是用户窗体输入的一个很有用的功能,而且很容易应用。

    97820

    运行Excel VBA的15种方法2

    图17 然后,在“Excel选项”对话框中,“从下列位置选择命令”下拉列表中选择“宏”,从下侧宏名列表中选择要添加的宏,单击“添加”按钮,将其添加到新建组中,如下图18所示。...图18 单击“确定”,这样就在Excel功能区中添加了一个名为“我的宏代码”的自定义选项卡,带有一个“新建组”,里面是与要运行的宏关联的命令按钮,如下图19所示。...图19 方法9:从VBE的运行菜单中运行VBA 在VBE中,首先将光标置于要运行的过程代码中,然后单击顶部菜单“运行——运行子过程/用户窗体”,如下图20所示。...图20 方法10:从VBE工具栏中运行VBA 在VBE中,首先将光标置于要运行的过程代码中,然后单击顶部调试工具栏中的“运行——运行子过程/用户窗体”按钮,如下图21所示。...End Sub 注意,将独立功能的代码或者重复的代码放置在单独的过程中,然后通过其它过程调用,这是一种好的编程习惯。 方法13:从工作表事件中调用VBA过程 可以基于事件来自动运行宏。

    54840

    问与答68: 如何改变复选框颜色?

    excelperfect Q:我如何才能改变复选框内部的颜色? A:在Excel中有3种不同类型的复选框,包括:用户窗体中的复选框、表单控件中的复选框、ActiveX控件中的复选框。...用户窗体中的复选框 对于用户窗体中的复选框,可以设置其BackColor属性来修改其内部颜色,如下图1所示,通过在属性窗口中设置其属性来改变复选框内部的颜色。 ?...图2 表单控件中的复选框 表单控件中的复选框位于功能区“开发工具”选项卡中“插入”按钮下的“表单控件”中,如下图3所示。 ?...图3 在工作表中插入“复选框”后,单击右键,在快捷菜单中选择“设置控件格式”命令,在弹出的“设置控件格式”对话框的“颜色与线条”选项卡中,单击“颜色”下拉框,选择想要填充的颜色,如下图4所示。 ?...图5 在工作表中插入ActiveX控件的“复选框”后,保持在设计模式下,单击属性,或者右键单击复选框,在弹出的快捷菜单中选择“属性”命令。

    4K30

    创建可调大小的用户窗体——使用VBA

    标签:VBA 在上篇文章:创建可调大小的用户窗体——使用Windows API中,我们使用Windows API实现了允许用户可以调整用户窗体的大小。本文仅使用VBA来实现同样的效果。...VBA解决方案:用户窗体包含一个对象,单击该对象时会记录鼠标的位置;随着鼠标的移动,用户窗体及其对象将根据新的鼠标位置重新定位或调整大小;当释放鼠标按钮时,停止移动以调整大小。...示例用户窗体 在VBE中,插入一个用户窗体,如下图1所示。...图1 其中,放置了三个元素:一个名为lstListBox的列表框,一个名为cmdClose的命令按钮,一个名为lblResizer的标签。...图2 在用户窗体代码模块中,输入下面的代码: Private resizeEnabled As Boolean Private mouseX As Double Private mouseY As Double

    1K30

    再谈 | 组态软件里面对远程桌面调用的方法

    王老湿在以前的文章里面介绍过如何在RSViewSE软件里面拉一个ActiveX控件(如有需要的小伙伴可自行在“剑指工控”中查找一下哦 ),此处就不再赘述,直接拉出来使用。...首先,在RSViewSE的画面里拉一个RDP控件 拉一个你电脑上版本最高的RDP控件 修改一下控件名称,为了调用的时候方便一点 然后在画面上再拉3个文本输入框,用于填写目标计算机的IP地址,目标计算机的用户名...设置RDP控件和文本框输入控件、按钮控件的属性面板都为VBA控制 然后进入脚本编辑页面 在按钮控件的按下或弹起事件里面写脚本内容 在编写脚本之前,我们需要先了解一个RDP控件的属性和方法。...连接效果如下: 如果你的RSViewSE画面里面插入RDP控件的时候一直报错,那就需要使用另外一种方法实现——VBA脚本里面的窗体 首先需要在VBA编辑器里面拉出来一个窗体 然后在这个窗体里面拉个RDP...的控件 然后在工具栏就会显示这个RDP的控件 拖拽至窗体上 双击窗体,编写连接脚本 SE的画面再调用时只需要调用这个窗体的显示即可 运行效果如下: 如果在运行时提示如下所示的错误 你需要修改注册表

    2.3K50

    类模块应用示例:获取单击的命令按钮名称

    标签:VBA,类模块,用户窗体 本示例演示,当用户单击用户窗体中的命令按钮时,会弹出该命令按钮名称信息。 这个示例来源于ozgrid.com,有兴趣的朋友可以研究。...在用户窗体上共有24个命令按钮,如下图1所示。 图1 当单击某个命令按钮时,会依次显示该命名按钮名称和标题信息,如下图2所示。...图2 在VBE中,插入一个类模块,将其重命名为“clsFrmCtls”,输入下面的代码: Public mName Public mFrm As Object Public WithEvents mCommandbutton...MSForms.CommandButton Private Sub mCommandButton_Click() RaiseEvent mFrm.SelectedChange(mName) End Sub 然后,插入一个用户窗体...,添加控件,如上图1所示,在该用户窗体代码模块中,输入下面的代码: Dim mcolEvents As Collection Public Sub SelectedChange(objCtr) MsgBox

    29530

    Vba菜鸟教程

    大家好,又见面了,我是你们的朋友全栈君。...(x) 判断x是否是数字,在vba.Information中 set i = Range(“A1”) ‘set,可以将对象赋值给变量 判断变量未赋值 is nothing 数组 dim arr() '定义数组...) '数组第七行,第二列 '最大值 Range("h3") = Application.WorksheetFunction.Max(arr) 'match是找到值在数组中的位置,参数是要找的值,要找的数组...'在VBA.Strings中,按符号分割字符串,返回数组 'Range("A1") = Split(Range("A1"),"-")(0) With Sheet1 'DateSerial...-属性-大小和位置均固定 窗体 vba编辑界面-右键插入-用户窗体 双击窗体或里面的控件进行编程 ShowModal 显示模式,为true不可以点击其他窗口,独占 Show 显示 Hide 隐藏 UserForm_Activate

    17.2K40

    Excel实战技巧65: 制作漂亮的用户窗体按钮——当鼠标移动到按钮上时高亮显示

    下面,我们来实现当鼠标移动到用户窗体按钮上时,会使用颜色高亮显示,让用户窗体更生动,如下图1所示。 ? 其实,你在图1中看到的按钮并不是用户窗体内置的传统命令按钮,而是使用图像控件来制作的。...然后,使用VBA代码来根据鼠标的位置切换这两个图像的可见性,从而实现按钮的动态变化。 在Excel工作表中创建按钮图像 使用文本框在Excel中创建按钮图像。...本例中,将使用绿色和白色/灰色格式来指示用户是否将鼠标悬停在特定按钮上。下图2是我制作的用于按钮图像的文本框。 ? 这里要注意的是,四个文本框的大小和格式设置都必须完全相同。...在用户窗体中绘制图像按钮 在VBE中,插入一个用户窗体,在其中放置一个标签控件、一个文本框控件以及一个图像控件,并调整成合适的大小和排列,如下图3所示。 ?...但是,如果用户将鼠标放置在除这两个按钮之外的其他地方时,我们不希望这两个按钮显示绿色,因此要使用用户窗体的MouseMove事件: Private SubUserForm_MouseMove(ByVal

    8.5K20

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

    标签:VBA,用户窗体 好的网站是非常优秀的学习资源,认真研究其分享的知识是我们快速提高水平的方法之一。...这个示例仍然来自于thesmallman.com,演示了用户窗体如何与工作表中的数据进行交互:如何使用Excel工作表中的数据填充用户窗体,并将编辑后的数据发送回工作表;并且在这个例中,只需在用户窗体中输入一个关键字...这听起来很合乎逻辑,但你会惊讶地发现,很少有用户窗体是用这种简单的逻辑来设置的。不知道为什么! 在这个示例中,我们会添加一些非常简洁的逻辑。...如果输入有效的注册号(在textbox1中)并按Enter键(回车键),则将预填充这个用户窗体。...如果找到了这些项目,则会使用该唯一注册号中的记录填充用户窗体。如果找不到该注册号,将显示错误消息。 编辑用户窗体后,有一个“更新”按钮。

    1.4K20

    窗体UserForm

    1、什么是窗体: 窗体是VBA里做好了的一个与用户交互的东西,在VBA编辑器界面,点击菜单插入-用户窗体,这样就创建了一个窗体界面,在VBA编辑器里的是一个编辑界面: ?...但是,个人认为窗体在VBA里使用的是不会很频繁的: 由于Excel VBA一般都是处理较为简单的东西,直接一个按钮运行一段程序就完了,所以一般都不怎么需要去制作交互界面。...而且Excel本身就是一个交互界面,有些提示性的东西可以直接在单元格中写。 Ribbon菜单又比以前的下拉式菜单交互性更加的友好了,窗体的使用更加的少了。...这是因为在Windows上使用的软件,基本都会有窗体的交互界面,特别是玩游戏用过外挂的人,可能会认为只有这种交互界面的才能算得上是一种软件。 3、代码编辑: 窗体和类相似,内部代码都属于这个窗体。...在VBA编辑器可以直接双击UserForm1那个界面进入到代码编辑,这样进入会自动插入代码: Private Sub UserForm_Click() End Sub 从名称可以看出,这个就是窗体的1

    2.5K20

    创建可调大小的用户窗体——使用Windows API

    标签:VBA,Windows API 在使用VBA创建用户窗体时,通常会将其设置为特定的大小。然而,通过一些编码技巧,可以为其实现类似的调整大小效果。...本文代码能够实现:允许调整用户窗体的大小;调整窗体大小时用户窗体的Resize事件能捕获;每次Resize事件后,对象的大小或位置都会发生变化。...首先,在VBE中插入一个标准模块,输入下面的代码: Public Const GWL_STYLE = -16 Public Const WS_CAPTION = &HC00000 Public Const...示例 在VBE中,插入一个用户窗体,如下图1所示。 图1 可以看到,该用户窗体上包括一个名为“lstListBOx”的列表框和一个名为“cmdClose”的命令按钮。...为此,需要从该用户窗体的底部和右侧了解这些对象的位置。如果与底部和右侧保持相同的距离,则这些元素似乎与该用户窗体同步移动。

    45030

    VBA数组(二)声明数组

    一、数组的分类 1、按维度划分 在上节中已经具体的介绍了VBA数组维度的概念。那么可以通过维度来划分数组,在VBA中数组供支持最大60维的数组,最常用的就是一至三维数组。...二、声明数组 在使用变量时,都需要先声明变量,同样在使用VBA数组时,首先也要声明数组,让系统在内存中为它分配一片连续的内存空间。...(数组的大小为上界-下界+1)。 如果希望数组下界是默认从1开始,可以在用户窗体或者模块的声明部分,通过语句Option Base 1 来设置数组下界默认从1开始。后期介绍示例会介绍。...数组中的元素就可以表示为数组名称(第一维索引号),索引号的范围在下界和上届之间。 2、声明静态二维数组 声明静态二维数组时,在不同的维度之间需要用英文逗号间隔。...首先在用户窗体、模块或者过程中使用dim或public语句声明一个没有下标的数组。比如: dim myarray() 然后在程序过程中使用ReDim语句重新定义该数组的大小。

    3.5K20

    示例工作簿分享:筛选数据

    标签:VBA,用户窗体 这是一个很好的示例,充分展示了VBA和用户窗体控件编程技术。 示例中有一个数据工作表Sheet1,包含有一个列表,每一行的单元格中都有很多用逗号分隔的数据,如下图1所示。...图1 工作表Sheet2中列出了数据中的唯一值,如下图2所示,可以根据工作表Sheet1数据添加而更新。 图2 创建了一个用户窗体,用来进行数据筛选,如下图3所示。...图3 这个示例工作簿有以下功能: 1.按F3会运行更新代码更新工作表Sheet2中的唯一项,并以红色标注出新添加的项。 2.按F4键将调出图3所示的用户窗体。...3.在用户窗体中: (1)左侧列表框列出了工作表Sheet2中的所有唯一项。 (2)在搜索框中输入内容时,会随着输入自动缩减左侧列表框中的内容。...(5)选择右侧列表框中的项目,单击“移除”按钮,该项目会自动移至左侧列表框。 (6)单击“筛选重置”按钮会重置列表框数据和工作表筛选。

    16110
    领券