利用VBA创建Excel新菜单
vba动态导航sheet
vba动态导航sheet摘要:1.VBA动态导航简介2.创建动态导航菜单3.实现菜单功能4.应用示例与代码解析5.总结与拓展正文:**一、VBA动态导航简介**VBA(Visual Basic for Applications)是Microsoft Office中的一种编程语言,适用于Access、Excel等办公软件。
VBA动态导航sheet是指在Excel中,利用VBA编程实现一个可以根据需求变化的导航菜单。
这种导航菜单在操作过程中可以自动调整,为用户提供便捷的操作体验。
**二、创建动态导航菜单**1.打开Excel,点击“开发”选项卡,进入“Visual Basic for Applications”编辑器。
2.在VBA编辑器中,插入一个模块,并编写如下代码:```vbaPrivate Sub Worksheet_SelectionChange(ByVal Target As Range) "根据选中区域的变化,动态调整菜单"此处可以编写相应的菜单项End Sub```3.回到Excel工作表,根据需要选择一个单元格。
上述代码中的“ SelectionChange”事件会在选中区域发生变化时触发,我们可以根据选中区域的内容,动态生成菜单项。
**三、实现菜单功能**1.编写菜单项点击事件。
在VBA编辑器中,继续编写以下代码:```vbaPrivate Sub CommandButton1_Click()"根据需求编写相应的功能实现"例如:选中区域的数据透视表分析Dim rng As RangeSet rng = Me.Range("A1:C10")Dim pivotTable As PivotTableSet pivotTable = Me.PivotTableWizard(Source:=rng, TitleText="数据透视表")End Sub```2.在Excel工作表上添加命令按钮,并将按钮与上述事件关联。
Excel2003_VBA自定义工具栏
Excel2003_VBA自定义工具栏Excel2003 VBA 自定义工具栏在 Office 中通过 VBA 开发工具栏和菜单,需使用 Office 提供的 CommandBar、CommandBarButton、CommandBarComboBox 等对象,这些对象即代表工具栏、工具栏按钮和工具栏下拉框,通过这些对象可编制出各类复杂的工具栏或菜单。
mandBars 集合该集合代表 Office 所有的工具栏,可用名称或索引号指定菜单栏或工具栏,但仅可用名称指定一个菜单、快捷菜单或子菜单。
如两个或两个以上自定义菜单或子菜单名称相同,则返回第一个具有该名称的对象。
其 Add 方法用于新建一个工具栏,并返回 CommandBar 对象。
语法:expression.AddName Position MenuBar Temporary 参数说明: Name 为可选的 Variant 类型,代表新工具栏的名称。
如果省略,则使用默认的名称;Position 为可选的 Variant 类型,代表新工具栏的位置。
该参数值可通过 VBA常量进行设置,如 msoBarLeft、msoBarTop、msoBarRight、msoBarBottom 常量设置新工具栏位于软件工具栏中位置;msoBarFloating 常量代表新工具栏可移动;msoBarPopup 常量代表新工具栏为快捷菜单等;MenuBar 为可选的 Variant 类型,用于设置是否用新工具栏替换活动工具栏; Temporary 为可选的 Variant 类型,用于设置新工具栏是否暂时有效。
mandBar 对象该对象代表应用程序中的工具栏,新建工具栏的控件均以该对象为载体。
1Controls 属性:返回 CommandBarControls 对象,代表指定工具栏中的所有控件。
2NameLocal 属性:返回由应用程序版本语言所设置的工具栏名称,如对软件的内置工具栏设置会出现错误。
Excel高级技巧使用VBA编程实现自定义功能
Excel高级技巧使用VBA编程实现自定义功能Microsoft Excel是一款广泛应用于数据分析、报表制作和管理的办公软件。
尽管Excel已经在内置功能方面提供了大量功能,但有时我们仍然需要自定义功能来满足特定的需求。
VBA(Visual Basic for Applications)编程为我们提供了扩展Excel功能的途径,可以实现各种高级技巧来提高工作效率。
本文将介绍几个使用VBA编程实现自定义功能的Excel高级技巧。
一、自定义函数自定义函数是VBA编程中最基础的一个功能,可以帮助我们实现特殊的计算和处理操作。
通过VBA编写自定义函数,我们可以扩展Excel内置函数的能力,并且可以根据具体需求来自定义函数的输入和输出。
例如,我们可以使用VBA编写一个自定义函数来计算斐波那契数列。
以下是一个简单实现斐波那契数列的VBA代码:```Function Fibonacci(n As Integer) As LongIf n <= 0 ThenFibonacci = 0ElseIf n = 1 ThenFibonacci = 1ElseFibonacci = Fibonacci(n - 1) + Fibonacci(n - 2)End IfEnd Function```在Excel中,我们可以直接在公式输入框中使用这个自定义函数,如`=Fibonacci(10)`,将会返回斐波那契数列中第10个数字。
二、扩展功能使用VBA编程,我们可以进一步扩展Excel的功能,为常用操作添加自定义的按钮、工具栏或菜单。
这样,我们可以通过点击按钮或选择菜单来触发VBA编写的自定义功能。
首先,我们需要打开VBA编辑器,可以通过按下`ALT + F11`键来快速打开。
然后,我们可以使用下面的代码来创建一个自定义按钮,并将其绑定到我们编写的VBA宏:```Sub AddCustomButton()Dim newButton As Object' 创建新的按钮Set newButton = CommandBars("Worksheet MenuBar").Controls("Tools").Controls.Add(Type:=msoControlButton) ' 设置按钮的属性With newButton.Caption = "自定义按钮".OnAction = "CustomMacro" ' 这里的CustomMacro是我们编写的VBA宏End WithEnd SubSub CustomMacro()' 这里写下我们的自定义功能MsgBox "Hello, World!"End Sub```以上的VBA代码将在Excel的工具菜单中添加一个名为"自定义按钮"的按钮,并将其绑定到名为"CustomMacro"的VBA宏。
Excel高级技巧使用VBA编写自定义函数
Excel高级技巧使用VBA编写自定义函数Excel是一款功能强大的电子表格软件,通过使用VBA(Visual Basic for Applications)编写自定义函数,可以进一步拓展Excel的功能和灵活性。
本文将介绍一些Excel高级技巧,以及如何使用VBA编写自定义函数来实现更复杂的计算和数据处理需求。
一、VBA简介VBA是一种基于Visual Basic语言的宏编程语言,用于扩展Microsoft Office套件中的各种应用程序的功能,包括Excel。
通过使用VBA,我们可以编写自己的功能代码,以实现定制化的功能。
二、使用VBA编写自定义函数的步骤1. 打开Excel,并按下ALT + F11快捷键,打开Visual Basic编辑器界面。
2. 在VBA编辑器界面中,选择插入(Insert)菜单,然后选择模块(Module)。
3. 在新建的模块中,编写自定义函数的VBA代码,例如:```vbaFunction MyFunction(ByVal num1 As Double, ByVal num2 As Double) As DoubleMyFunction = num1 * num2End Function```上述代码定义了一个名为MyFunction的自定义函数,接受两个参数num1和num2,并返回它们的乘积。
4. 保存VBA代码,并返回Excel界面。
5. 在Excel表格中的某个单元格中输入`=MyFunction(2, 3)`,按下回车键,该单元格将显示结果6,即2和3的乘积。
通过以上步骤,我们成功地使用VBA编写了一个自定义函数,并在Excel中调用并使用它。
三、自定义函数的应用示例自定义函数可以用于更复杂的计算和数据处理需求。
以下是一个实际示例,展示了如何使用VBA编写自定义函数。
假设我们有一个Excel表格,其中包含了学生的成绩信息,包括科目和分数。
我们想计算每个科目的平均分。
ExcelVBA编程新建用户窗体
ExcelVBA编程新建⽤户窗体
Excel VBA编程新建⽤户窗体
在Excel⼯作表中,当InputBox和MsgBox函数在不能满⾜⽤户应⽤程序的要求时,⽤户可以创建⾃定义⽤户窗体,来满⾜获取更多数据信息的要求。
⽤户不仅能够在⽤户窗体内添加所需的各种控件,⽽且还可为各控件设置相关属性及合理地安排他们的布局。
同时,根据需要为窗体及其中的控件编写特定事件的程序代码,从⽽创建出各种复杂、实⽤的⽤户界⾯。
在当前⼯作表中,选择【开发⼯具】选项卡,单击【代码】组中的Visual Basic按钮,打开VBE环境窗⼝。
然后在该窗⼝中,执⾏【插⼊】|【⽤户窗体】命令,这样就创建了⼀个新的⽤户窗体(UserForm1),如图12-1所⽰。
图12-1 新建⽤户窗体(UserForm)
新创建的⽤户窗体中没有任何控件,在⽤户窗体的标题栏中显⽰了当前⽤户窗体的标题(Caption),和⼀个【关闭】按钮。
⽽窗体中则为⼀个个灰⾊的点组成的⽹格,每个(上、下、左、右)⽹格的⾼度和宽度的间距为6磅,⽹格的的间距可以修改。
⽹格的是⽤于帮助⽤户放置控件的设计⼯具,当窗体在运⾏状态时则不显⽰⽹格。
创建⽤户窗体时,还默认打开了【控件⼯具箱】,该⼯具箱中包含了VBE中所有的可⽤控件,可⽤于向⽤户窗体中添加控件。
提⽰⽤户还可以在VBE环境窗⼝的【⼯程资源管理器】窗⼝中右击,在弹出的快捷菜单中,执⾏【插⼊】|【⽤户窗体】命令,来创建⽤户窗体。
执⾏
控件⼯具箱。
ExcelVBA多级菜单(利用单元变动事件)
ExcelVBA多级菜单(利⽤单元变动事件)先去重复,再取唯⼀值做序列Sub test001()Dim qhs01 As RangeDim n As LongDim qhn01 As LongDim xulie1 As StringWith Sheets("⾓⾊表")qhn01 = .Range("b1000000").End(xlUp).Rown = 1For Each qhs01 In .Range("b2:b" & qhn01)If Application.WorksheetFunction.CountIf(.Range("$b$2:" & qhs01.Address), qhs01) = 1 Thenxulie1 = xulie1 & qhs01 & ","' .Cells(n, 1) = qhs01n = n + 1End IfNextEnd WithFor i = 3 To 1003With Sheets("⽤户设置").Range("f" & i).Validation.Delete.Add Type:=xlValidateList, Formula1:=xulie1End WithNextEnd Sub先去重复,再取唯⼀值做序列实际运⽤选的时候增加⼆级菜单,选好⼆级菜单是添加⼆级菜单后⾯的描述Private Sub Worksheet_Change(ByVal Target As Range)Dim qhn01, qhn02 As Long 'qhn01获取当前选中单元格⾏,qhn02获取⾓⾊表最后⼀⾏有数据的单元格⾏Dim i As LongDim QH_xuelie01 As String '序列变量qhn02 = Sheets("⾓⾊表").Range("b1000000").End(xlUp).Rowqhn01 = ActiveCell.RowIf Target.Column = 6 Then'qhn01 = ActiveCell.RowIf Sheets("⽤户设置").Range("f" & qhn01) <> "" ThenFor i = 2 To qhn02If Sheets("⾓⾊表").Range("b" & i) = Sheets("⽤户设置").Range("f" & qhn01) ThenQH_xuelie01 = QH_xuelie01 & Sheets("⾓⾊表").Range("c" & i) & ","End IfNextElseSheets("⽤户设置").Range("g" & qhn01).Validation.DeleteSheets("⽤户设置").Range("g" & qhn01).ClearContentsExit SubEnd IfWith Sheets("⽤户设置").Range("g" & qhn01).Validation.Delete.Add Type:=xlValidateList, Formula1:=QH_xuelie01End WithElseIf Target.Column = 7 Then'qhn01 = ActiveCell.RowIf Sheets("⽤户设置").Range("g" & qhn01) <> "" ThenSheets("⽤户设置").Range("h" & qhn01) = Application.WorksheetFunction.VLookup(Sheets("⽤户设置").Range("g" & qhn01), Sheets("⾓⾊表").Range("c2:d" & qhn02), 2, 0)ElseSheets("⽤户设置").Range("h" & qhn01).ClearContentsExit SubEnd IfEnd IfEnd IfEnd Sub实际运⽤选的时候增加⼆级菜单,选好⼆级菜单是添加⼆级菜单后⾯的描述。
通过VBA自定义向Excel添加工具栏
通过VBA自定义向Excel添加工具栏Office由于提供了VBA,为大家开发一些定制功能提供了一种途径。
但是如何实现工具栏中的命令与宏进行绑定,对于初学则来说是一个不小的门槛。
今天,给大家介绍一下在Excel里写完宏后,如何通过宏自动生成工具栏。
如图:在VBA中将要用到CommandBar,CommandBarButton两个对象。
Option Explicit'定义全局变量Private zyi_Bar As CommandBarPrivate zyi_ComBarBtn As CommandBarButton'-------------------------------------------------------------------------------------------------------------'增加工具栏'-------------------------------------------------------------------------------------------------------------Sub AddToolBar()'''' mandBars.Add(Name:="zy").Visible = TrueDim strBarName As StringDim strParam As StringDim strCaption As StringDim strCommand As StringDim nIndex As IntegerDim nFaceId As IntegerDim cBar As CommandBarstrBarName = "ZYI_TOOL"For Each cBar In mandBarsIf = strBarName ThenSet zyi_Bar = cBarGoTo 20End IfNext'On Error GoTo 10'Set zyi_Bar = mandBars(strBarName)'If zyi_ = strBarName Then' GoTo 20 '已经存在' zyi_Bar.Delete'End If'10:On Error GoTo 100Set zyi_Bar = mandBars.Add(Name:=strBarName)20:zyi_Bar.Visible = TrueOn Error GoTo 100'-----------------------------------------------------------'1. 复制工作表nIndex = 1strCaption = "复制工作表"strParam = "复制工作表的单元格内容及格式!"strCommand = "复制工作表"nFaceId = 271If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End If'-----------------------------------------------------------'2. 合并单元格nIndex = 2strCaption = "合并单元格"strParam = "合并单元格以及居中"strCommand = "合并单元格"nFaceId = 29If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End If'-----------------------------------------------------------'3. 居中nIndex = 3strCaption = "居中"strParam = "水平垂直居中"strCommand = "居中单元格"nFaceId = 482If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End If'-----------------------------------------------------------'4. 货币nIndex = 4strCaption = "货币"strParam = "货币"strCommand = "货币"nFaceId = 272If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End If'-----------------------------------------------------------'5. 将货币数字转换为大写nIndex = 5strCaption = "删除列"strParam = "删除列"'宏名称strCommand = "删除列"nFaceId = 1668If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End IfnIndex = nIndex + 1While nIndex < zyi_Bar.Controls.Countzyi_Bar.Controls(nIndex).DeleteWend'-----------------------------------------------------------'6. 分割条zyi_Bar.Controls(zyi_Bar.Controls.Count).BeginGroup = True'-----------------------------------------------------------'7. 将货币数字转换为大写nIndex = 6strCaption = "人民币"strParam = "人民币由数字转换为大写"'宏名称strCommand = "To大写人民币"nFaceId = 384If zyi_Bar.Controls.Count < nIndex ThenAddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId ElseIf zyi_Bar.Controls(nIndex).Caption <> strCaption Then AddComBarBtn strParam, strCaption, strCommand, nIndex, nFaceId End IfnIndex = nIndex + 1While nIndex < zyi_Bar.Controls.Countzyi_Bar.Controls(nIndex).DeleteWend'-----------------------------------------------------------'9. 分割条zyi_Bar.Controls(zyi_Bar.Controls.Count).BeginGroup = True100:End Sub'-------------------------------------------------------------------------------------------------------------'向工具栏动态添加按钮'-------------------------------------------------------------------------------------------------------------Sub AddComBarBtn(strParam As String, strCaption As String, strCommand As String, nIndex As Integer, nFaceId As Integer)'Set zyi_ComBarBtn = zyi_Bar.Controls.Add( _ID:=1, _Parameter:=strParam, _Before:=nIndex, _Temporary:=True)With zyi_ComBarBtn.Caption = strCaption.Visible = True.OnAction = strCommand.FaceId = nFaceIdEnd WithEnd Sub通过以上两个函数,就可以实现自动添加工具栏及按钮。
VBA中的动态列表与下拉菜单
VBA中的动态列表与下拉菜单VBA(Visual Basic for Applications)是一种用于在各种Microsoft Office应用程序中编写宏的编程语言。
在Excel中,VBA可用于创建动态列表和下拉菜单,这可以为用户提供更高效、易于使用的工作环境。
本文将重点介绍如何使用VBA 在Excel中创建动态列表和下拉菜单。
动态列表是一种根据特定条件而变化的列表。
通过使用VBA,我们可以根据特定条件来更新和管理动态列表。
一种常见的用法是根据某个单元格的值动态更改列表内容。
下面是一个简单的例子,以说明如何创建一个基于单元格值的动态列表。
首先,我们需要在工作表上创建一个下拉菜单。
在Excel 中,我们可以使用数据验证功能来创建下拉菜单。
但是,通过使用VBA,我们可以更灵活地控制下拉菜单的内容。
以下是创建基于单元格值的动态列表的步骤:步骤1:打开Visual Basic编辑器(可通过按下ALT + F11键来打开)。
步骤2:在“项目资源管理器”面板中,双击打开要添加VBA代码的工作簿。
步骤3:在工作簿的项目窗口中,双击打开“Sheet1”(或其他你想要创建动态列表的工作表)。
步骤4:在工作表中的代码窗口中,输入以下VBA代码:```VBAPrivate Sub Worksheet_Change(ByVal Target As Range)If Not Application.Intersect(Target, Range("A1")) Is Nothing Then'在下面的代码中,你可以按照你的需求更新列表的内容With Range("A2:A6").Validation.Delete.Add Type:=xlValidateList,AlertStyle:=xlValidAlertStop, _Operator:=xlBetween,Formula1:="=INDIRECT($A$1)"End WithEnd IfEnd Sub```上述VBA代码将在单元格A1的值更改时自动更新A2到A6的动态列表。
Excel的工具栏和菜单栏VBA源码实例
工具栏和菜单栏工具栏和菜单栏的运用更多时候是伴随着加载宏和个性Excel界面的出现而出现。
在不断加深对ExcelVBA 的理解和运用,我们编程的思路渐渐会转到考虑代码的通用性和应用方案上,将代码和Excel数据源分开。
因此,制作更多具有通用功能的加载宏(不管是xla加载宏,还是Com加载宏),可以最大极限的发挥VBA编程的魅力,而不是要求用户强制启用宏。
也正是因为这个原因,在我们去学习工具栏和菜单栏时,要明白的一个道理是,制作工具栏仅仅是为了加载宏等具体运用的实现,不要一味地去追求工具栏的花哨。
一、几个基本概念在开始本节之前,先理解什么是命令栏?命令栏(CommandBars):是工具栏、菜单栏和快捷菜单的统称。
工具栏:带有按钮和选项的工具条,使用这些按钮和选项可执行命令。
如下图:菜单栏:标题栏下的水平栏,包括菜单名称。
如下图快捷菜单:又叫弹出式菜单,鼠标右键单击。
如下图。
二、CommandBars集合对象通过上面几幅图片的直观概念之后,我们接下来理解CommandBar集合。
所有的工具栏和菜单栏代码都是围绕Commandbars集合展开的。
CommandBarControlsCommandBarButton属性必须是msoControlButton。
)CommandBarComboBox见、或该、msoControlGraphicPopup、msoControlButtonPopup、。
NameTypePostionTemporaryCaptionOnActionFaceIDStyleEnableTop/Left/Width/HightBeginGroupControlsAdd方法Findcontrols方法下面将通过实例来解释上述属性、参数和方法的运用。
三、实例代码1、建立一命令栏即建立了一个工具栏。
一般的,我们会相应的定义一个Commandbar对象来操作这个自定义工具栏,如下代码:SubAddCommandBar1()'添加一自定义工具栏DimcmdBarAsCommandBarSetcmdBar=EndSub但,Excel好像任何变化,这是因为自定义工具栏的默认Visible为False。
运用VBA实现EXCLE的菜单和工具栏方法[51自学网园地]
联系我们
论坛帮助
恢复默认设置
登录 |注册 |搜索 |风格 |论坛状态 |论坛展区 |51视频教程 |设计素材 |积分计划 |我的勋章 |版主报到
审核帖子
功能菜单 |我能做什么
51自学网园地 → 信息化办公--[区版:samohu] → Microsoft Excel → 运用VBA实现EXCLE的菜单和工具栏方法
所复制的菜单栏或工具栏的名字就出现在工作簿框中。
用户可以删除原始的工作区级的菜单栏或工具栏,单击“自定义”对话框中的“工具栏”表,选择要删除的菜单栏或工具栏的名字,然后单击“删除”按钮。如果用户没有删除菜单栏或工具栏在工作区的版本,还可以对其进行更改而不会影响到工作簿中保存的版本。如果用户对工作区中的菜单栏或工具栏进行了更改,而且想更新工作簿中的版本使它同工作区的版本保持一致,可以再次将工作区中的版本复制到工作簿里,替换工作簿原来的版本。
帖子评论
选取类型:中立 支持 反对 选取观点 精彩,一针见血 观点独到 说得很对 你说得有道理 选取观直是胡说八道
观点标题:
验证码:
观点内容:
(不支持HTML)
将菜单栏或工具栏从工作区移动到工作簿
如果“自定义”对话框尚未打开,那么用鼠标指到“视图”菜单里的“工具栏”上,然后单击“自定义”。
在“工具栏”表上单击“附加”按钮。
显示出“附加工具栏”对话框。
在“自定义”对话框里,单击想要复制到活动工作簿的菜单栏或工具栏的名字。
单击“复制”。
请以客观、真实地作出评论,并注意语言文明;
观点发表后不能作出更改;
VBA列表和下拉菜单的设计和应用
VBA列表和下拉菜单的设计和应用在 Excel 中,VBA (Visual Basic for Applications) 是一种强大的编程语言,可以帮助用户自动化处理数据和增强工作效率。
其中,列表和下拉菜单是 VBA 中常用的功能,使用它们可以使用户使用工作表时更加便捷和高效。
本文将介绍如何设计和应用 VBA 列表和下拉菜单,帮助您更好地利用 Excel。
一、设计列表列表可以让用户从预定义的选项中进行选择,而不必手动输入。
通过 VBA,您可以轻松地创建和管理这些列表。
1. 创建列表:要创建列表,首先需要确定在哪个工作表和单元格中放置它。
然后,在 VBA 编辑器中,打开要添加列表的工作表,并选择该工作表的对象库。
接下来,选择工具栏中的 "插入" 选项,并在下拉菜单中选择 "列表箱",然后在工作表上绘制出所需的列表框。
2. 添加选项:选中列表框,然后在 "属性窗口" 中选择 "列表项"。
在 "行" 区域中,输入预定义的选项,每个选项一行。
您可以根据需要输入适当的选项名称。
3. 设置链接:要使列表框与特定的单元格相关联,可以设置链接。
选中列表框,然后在 "属性窗口" 中选择"LinkedCell",然后选择与列表相关联的单元格。
这样,当用户选择列表中的选项时,相关单元格将自动更新。
二、下拉菜单的设计与应用下拉菜单可帮助用户从预定义的选项中选择数据,从而提高数据输入的准确性和速度。
通过 VBA,您可以轻松地设计和应用下拉菜单。
1. 创建菜单:首先,选中要放置下拉菜单的单元格,并在 VBA 编辑器中打开要应用下拉菜单的工作表对象库。
然后,选择菜单栏上的 "数据" 选项,并在下拉菜单中选择"数据验证" 。
2. 设置数据源:在 "数据验证" 对话框中,选择 "设置" 选项卡,然后选择 "列表"。
利用VBA创建Excel新菜单
.Caption = "月汇总(&M)"
.FaceId = 110
.OnAction = "Macro3"
End With
'添加第二个子菜单
Set SubMenuItem = MenuItem.Controls.Add _
使用VBA,可以很方便地向Excel菜单栏添加新菜单。
背景知识
1、菜单栏属于CommandBars集合,可以通过菜单栏名称或索引值对其进行引用:
CommandBars(“Worksheet Menu Bar”)或CommandBars(1)
2、新添加的菜单是一个弹出式控件,其类型为msoControlPopup。
Else
'将新菜单添加到帮助菜单之前
Set NewMenu = CommandBars(1).Controls _
.Add(Type:=mቤተ መጻሕፍቲ ባይዱoControlPopup, Before:=HelpMenu.Index, _
Temporary:=True)
Dim MenuItem As CommandBarControl
Dim SubMenuItem As CommandBarButton
On Error Resume Next
'如果菜单已存在,则删除该菜单
CommandBars(1).Controls("统计(&S)").Delete
(Type:=msoControlButton)
With SubMenuItem
.Caption = "季度汇总(&Q)"
使用VBA自定义Excel功能按钮与菜单
使用VBA自定义Excel功能按钮与菜单自定义功能按钮与菜单是提高Excel使用效率的一个重要方法。
通过使用VBA(Visual Basic for Applications)编程语言,我们可以在Excel中自定义各种功能按钮和菜单,以满足特定需求,并简化操作流程。
在本文中,我们将学习如何使用VBA自定义Excel功能按钮与菜单。
在Excel中,功能按钮可以是工具栏按钮、快速访问工具栏按钮或自定义Ribbon菜单按钮。
我们可以为这些按钮分配宏,以执行我们期望的操作。
首先,我们将学习如何创建一个自定义功能按钮。
以下是创建自定义功能按钮的步骤:步骤1:打开Excel并进入开发者选项卡。
要进入开发者选项卡,可以右键点击Excel的任意工具栏,然后选择“自定义工具栏”并勾选“开发者”选项。
步骤2:进入开发者选项卡后,单击“插入”下的按钮控件,然后在Excel中拖动以确定按钮的大小。
步骤3:双击按钮,将进入VBA编辑器。
在VBA编辑器中,我们可以编写按钮的宏代码。
步骤4:编写宏代码以执行我们期望的操作。
例如,我们可以编写一个宏代码来计算选定单元格的总和并将结果显示在消息框中。
步骤5:退出VBA编辑器并返回到Excel界面。
此时,我们的自定义功能按钮已经创建完成。
现在,每当我们单击自定义功能按钮时,它将执行我们之前编写的宏代码,从而实现我们期望的操作。
在创建自定义功能按钮的过程中,我们可以进行更多的设置。
例如,我们可以为按钮设置名称、提示信息、快捷键和图标。
这些设置将使按钮更加易于识别和使用。
除了自定义功能按钮,我们还可以使用VBA自定义菜单。
自定义菜单将一组相关的功能命令组合在一起,并以菜单的形式展示。
以下是创建自定义菜单的步骤:步骤1:进入VBA编辑器,并创建一个新的模块。
在该模块中,我们将存储自定义菜单的宏代码。
步骤2:编写宏代码以创建自定义菜单。
我们可以使用VBA代码中的`CommandBars`对象来创建菜单栏和菜单项。
ExcelVBA编程进阶自定义用户界面和交互式功能
ExcelVBA编程进阶自定义用户界面和交互式功能ExcelVBA编程进阶:自定义用户界面和交互式功能在Excel中使用VBA编程可以帮助我们更好地完成各种工作任务。
不仅可以进行数据处理、函数计算,还可以通过编写宏和用户界面,实现自定义的交互式功能。
本文将介绍如何进一步提升ExcelVBA编程技巧,实现自定义用户界面和交互式功能。
一、自定义用户界面要实现自定义用户界面,我们可以利用Excel的用户窗体功能。
用户窗体可以包含各种控件,如按钮、文本框、下拉列表等,以便用户进行输入和操作。
1.1 创建用户窗体在Excel中,打开开发工具选项卡,点击“插入”菜单下的“用户窗体”按钮,即可创建一个用户窗体。
然后,我们可以对用户窗体进行设计和布局。
通过拖拽和调整控件的位置和大小,可以实现界面的自定义。
1.2 添加控件在用户窗体上添加控件,可以通过选中“工具箱”中的控件图标,然后在用户窗体上拖拽绘制。
根据不同的需求,我们可以添加按钮、文本框、标签、下拉列表等控件。
1.3 设计控件属性在设计用户界面时,我们需要设置控件的属性,以满足具体的功能需求。
对于按钮控件,我们可以设置其名称、文本、大小和位置等属性。
对于文本框控件,我们可以设置其默认值、大小、位置和格式等属性。
二、交互式功能除了自定义用户界面,VBA编程还可以实现交互式功能,使用户能够直观地与Excel进行交互。
2.1 按钮点击事件我们可以在VBA代码中编写按钮的点击事件,实现一系列动作。
通过按钮点击事件,可以执行诸如计算、查找、排序等操作,增加程序的灵活性和可交互性。
2.2 文本框输入事件文本框是用户输入文字的控件。
我们可以编写文本框的输入事件,实现对用户输入的处理。
通过文本框输入事件,可以进行输入数据的验证、格式化等操作。
2.3 下拉列表选择事件下拉列表是一种常用的控件,用于提供用户选择的选项。
我们可以编写下拉列表的选择事件,根据用户选择的不同项,执行相应的操作。
如何使用Excel进行VBA编程
如何使用Excel进行VBA编程使用Excel进行VBA编程的方法可以帮助用户在Excel中自动执行特定任务,并提高工作效率。
以下是一些实用的步骤,帮助您了解如何进行VBA编程。
第一步:启用Excel的开发人员选项为了使用VBA编程,您需要在Excel中启用开发人员选项。
请按照以下步骤操作:1. 打开Excel,并单击工具栏上的“文件”选项。
2. 在弹出的菜单中,选择“选项”。
3. 在Excel选项窗口中,选择“自定义功能区”。
4. 在右侧的“主选项卡”列表中,勾选“开发人员”,然后单击“确定”按钮。
现在,您将在Excel工具栏上看到一个新的“开发人员”选项卡。
第二步:打开Visual Basic编辑器在Excel中,VBA代码是通过Visual Basic编辑器编写和编辑的。
按照以下步骤操作:1. 单击Excel工具栏上的“开发人员”选项卡。
2. 在“代码”组中,单击“Visual Basic”按钮。
这将打开Visual Basic编辑器窗口,您可以在其中编写和编辑VBA 代码。
第三步:编写VBA代码在Visual Basic编辑器中,您可以开始编写VBA代码。
以下是一些示例代码,帮助您入门:1. 创建一个新的子程序:在编辑器窗口中,单击“插入”菜单,然后选择“模块”。
在模块窗口中,您可以键入以下简单的VBA代码:```Sub HelloWorld()MsgBox "Hello, World!"End Sub```2. 编写一个简单的循环:您可以使用VBA编写循环以重复执行任务。
以下是一个示例:```Sub NumberLoop()Dim i As IntegerFor i = 1 To 10Cells(i, 1).Value = iNext iEnd Sub```3. 创建一个自定义函数:您可以使用VBA编写自己的函数,并在Excel中调用。
以下是一个示例:```Function AddNumbers(a As Integer, b As Integer) As IntegerAddNumbers = a + bEnd Function```这些示例只是VBA编程的一小部分。
VBA的使用方法与实战案例解析
VBA的使用方法与实战案例解析在Excel应用程序中,Visual Basic for Applications(VBA)是一种强大的编程语言,它可以帮助用户自动化繁琐的任务和处理大量的数据。
本文将介绍VBA的基本使用方法,并通过几个实战案例来解析其实际应用。
一、VBA的基本使用方法1. 启用开发工具:在Excel中使用VBA代码之前,首先需要启用开发工具。
点击Excel上方的“文件”选项卡,在下拉菜单中选择“选项”,然后点击“自定义功能区”并勾选“开发人员”选项。
2. 打开VBA编辑器:在开发选项卡中,点击“Visual Basic”按钮即可打开VBA编辑器。
你也可以通过按下"ALT+F11"键来快速打开VBA编辑器。
3. 编写VBA代码:在VBA编辑器中,可以看到一个名为“项目导航器”的窗口,其中包含了当前工作簿的所有对象。
选择一个对象,然后点击“插入”菜单,选择“模块”即可创建一个新的模块。
在模块中编写VBA代码。
4. 运行VBA代码:在VBA编辑器中,点击“运行”选项卡上的“运行子过程”按钮可以直接运行整个代码或者点击F5键进行代码的运行。
二、实战案例解析1. 数据分析与处理假设你有一个包含大量数据的Excel表格,并且需要对这些数据进行分析和处理。
通过编写VBA代码可以大大简化这个过程。
首先,你可以使用VBA代码自动筛选数据。
通过指定特定的条件,VBA代码可以自动筛选数据并将结果显示在新的工作表中。
例如,你可以编写代码来筛选销售额超过一定金额的订单。
其次,你可以使用VBA代码自动计算和生成报表。
通过编写相关的公式和逻辑,VBA代码可以自动计算各种指标,并生成相应的报表。
例如,你可以编写代码来计算销售额、利润率等指标,并将结果显示在新的工作表中。
2. 自动化任务VBA代码还可以帮助你自动化一些繁琐的任务。
例如,你可以编写代码来自动填充表格中的某些单元格,自动调整表格的格式等。
利用VBA创建自定义Excel功能
利用VBA创建自定义Excel功能Excel是一款功能强大的电子表格软件,它提供了很多内置的功能,但有时我们需要根据自己的需求创建一些自定义功能。
VBA(Visual Basic for Applications)是一种编程语言,它可以与Excel进行交互,帮助我们实现各种自定义功能。
本文将介绍如何利用VBA创建自定义Excel功能。
首先,打开Excel并按下Alt+F11键呼出VBA编辑器。
在VBA编辑器中,可以看到项目资源管理器窗口和代码窗口。
在项目资源管理器中,双击“这台工作簿”以打开代码窗口,这是用于编写与当前工作簿相关的代码的地方。
一、添加自定义功能按钮首先,让我们来添加一个自定义功能按钮,用于触发我们的自定义功能。
在代码窗口中,插入以下代码:```vbaSub AddCustomButton()Dim btn As ButtonSet btn = ActiveSheet.Buttons.Add(100, 100, 100, 30)With btn.Caption = "自定义功能".OnAction = "CustomFunction"End WithEnd Sub```这段代码定义了一个名为“AddCustomButton”的子过程,该过程将在当前工作表上创建一个按钮,并为其定义了名称和触发事件。
按钮的位置和大小可以根据实际需要进行调整。
在代码中,我们将按钮的位置设置为(100,100),宽度为100,高度为30。
按钮的标题设置为“自定义功能”,并指定了按钮被点击时触发的事件为“CustomFunction”。
接下来,我们需要定义一个名为“CustomFunction”的过程,该过程将是我们自定义的功能的具体实现。
二、实现自定义功能在代码窗口中,插入以下代码:```vbaSub CustomFunction()'在这里编写自定义功能的代码End Sub```在“CustomFunction”过程中,我们可以编写我们自定义功能的具体代码。
通过VBA自定义向Excel添加工具栏
通过VBA自定义向Exce l添加工具栏Office由于提供了VB A,为大家开发一些定制功能提供了一种途径。
但是如何实现工具栏中的命令与宏进行绑定,对于初学则来说是一个不小的门槛。
今天,给大家介绍一下在Excel里写完宏后,如何通过宏自动生成工具栏。
如图:在VBA中将要用到Comm andBar,Command BarBut ton两个对象。
OptionExplici t'定义全局变量Private zyi_Bar As Command BarPrivate zyi_Com BarBtn As Command BarBut ton'-------------------------------------------------------------------------------------------------------------'增加工具栏'-------------------------------------------------------------------------------------------------------------Sub AddTool Bar()'''' Applica mand Bars.Add(Name:="zy").Visible = TrueDim strBarN ame As StringDim strPara m As StringDim strCapt ion As StringDim strComm and As StringDim nIndexAs IntegerDim nFaceId As IntegerDim cBar As Command BarstrBarN ame = "ZYI_TOO L"For Each cBar In Applica mand BarsIf = strBarN ame ThenS et zyi_Bar = cBarGoTo 20End IfNext'On Error GoTo 10'Set zyi_Bar = Applica mand Bars(strBarN ame)'If zyi_Ba = strBarN ame Then' GoTo 20 '已经存在' zyi_Bar.Delete'End If'10:On Error GoTo 100Set zyi_Bar = Applica mand Bars.Add(Name:=strBarN ame)20:zyi_Bar.Visible = TrueOn Error GoTo 100'-----------------------------------------------------------'1. 复制工作表nIndex= 1strCapt ion = "复制工作表"strPara m = "复制工作表的单元格内容及格式!"strComm and = "复制工作表"nFaceId = 271If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End If'-----------------------------------------------------------'2. 合并单元格nIndex= 2strCapt ion = "合并单元格"strPara m = "合并单元格以及居中"strComm and = "合并单元格"nFaceId = 29If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End If'-----------------------------------------------------------'3. 居中nIndex= 3strCapt ion = "居中"strPara m = "水平垂直居中"strComm and = "居中单元格"nFaceId = 482If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End If'-----------------------------------------------------------'4. 货币nIndex= 4strCapt ion = "货币"strPara m = "货币"strComm and = "货币"nFaceId = 272If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End If'-----------------------------------------------------------'5. 将货币数字转换为大写nIndex= 5strCapt ion = "删除列"strPara m = "删除列"'宏名称strComm and = "删除列"nFaceId = 1668If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End IfnIndex= nIndex+ 1While nIndex< zyi_Bar.Control s.Countzyi_Bar.Control s(nIndex).DeleteWend'-----------------------------------------------------------'6. 分割条zyi_Bar.Control s(zyi_Bar.Control s.Count).BeginGr oup = True'-----------------------------------------------------------'7. 将货币数字转换为大写nIndex= 6strCapt ion = "人民币"strPara m = "人民币由数字转换为大写"'宏名称strComm and = "To大写人民币"nFaceId = 384If zyi_Bar.Control s.Count < nIndexThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId ElseIfzyi_Bar.Control s(nIndex).Caption <> strCapt ion ThenAddComB arBtnstrPara m, strCapt ion, strComm and, nIndex, nFaceId End IfnIndex= nIndex+ 1While nIndex< zyi_Bar.Control s.Countzyi_Bar.Control s(nIndex).DeleteWend'-----------------------------------------------------------'9. 分割条zyi_Bar.Control s(zyi_Bar.Control s.Count).BeginGr oup = True100:End Sub'-------------------------------------------------------------------------------------------------------------'向工具栏动态添加按钮'-------------------------------------------------------------------------------------------------------------Sub AddComB arBtn(strPara m As String, strCapt ion As String, strComm and As String, nIndexAs Integer, nFaceId As Integer)'Set zyi_Com BarBtn = zyi_Bar.Control s.Add( _ID:=1, _P aramet er:=strPara m, _B efore:=nIndex, _T empora ry:=True)With zyi_Com BarBtn.Caption = strCapt ion.Visible = True.OnActio n = strComm and.FaceId= nFaceIdEnd WithEnd Sub通过以上两个函数,就可以实现自动添加工具栏及按钮。
VBA实现自定义菜单与工具栏按钮的步骤与技巧
VBA实现自定义菜单与工具栏按钮的步骤与技巧自定义菜单和工具栏按钮是VBA中常用的功能,它们可以提高工作效率和用户体验。
通过自定义菜单和工具栏按钮,我们可以将经常使用的命令集中到一个菜单或按钮上,方便用户快速访问。
下面我们将介绍VBA实现自定义菜单和工具栏按钮的步骤与技巧。
步骤一:打开Excel的开发人员选项要使用VBA自定义菜单和工具栏按钮,首先需要打开Excel的开发人员选项。
打开Excel后,点击工具栏上的“文件”选项卡,然后选择“选项”。
在弹出的对话框中,选择“自定义功能区”选项卡,并勾选“开发人员”复选框,点击“确认”按钮即可。
步骤二:添加自定义菜单或工具栏在打开的Excel中,我们可以看到多出了一个“开发人员”选项卡。
在这个选项卡中,我们可以创建自定义菜单或工具栏。
点击“开发人员”选项卡上的“自定义菜单”或“自定义工具栏”按钮,选择“新建”命令,即可创建一个新的自定义菜单或工具栏。
步骤三:编辑自定义菜单或工具栏在创建好的自定义菜单或工具栏上,我们可以添加各种命令和功能。
例如,可以添加一个新的菜单项,命令类型可以是内置的Excel命令,也可以是自定义的VBA命令。
另外,还可以设置快捷键、改变显示顺序等。
在添加自定义命令时,可以使用VBA代码来实现更复杂的功能。
在自定义菜单或工具栏的编辑模式下,点击“新建”按钮,在弹出的对话框中选择“宏”命令。
然后,在代码编辑器中输入你所需的VBA代码,以实现相应的功能。
例如,可以编写一个VBA宏来自动进行数据处理、图表生成或其他任务。
步骤四:设置自定义菜单或工具栏的显示完成自定义菜单或工具栏的编辑后,需要设置它们在Excel中的显示方式。
在自定义菜单或工具栏的编辑模式下,点击“常规”选项卡,在“显示”选项中选择显示的位置,可以选择在菜单栏或工具栏中显示。
步骤五:保存并使用自定义菜单或工具栏在设置好自定义菜单或工具栏的显示方式后,点击“文件”选项卡,然后选择“选项”并在弹出的对话框中点击“确认”按钮,保存配置的改动。
Excel VBA自定义菜单和菜单栏
Excel VBA自定义菜单和菜单栏(江羽收集整理)【目录】前言 (3)一、简介 (3)二、命令栏 (4)三、控件常量 (4)四、菜单栏 (6)4.1A DD方法应用于C OMMAND B ARS对象 (6)4.2返回命令栏控件的ID (7)4.3确定活动菜单栏的名称 (7)4.4保存(内置或自定义菜单栏的)活动状态 (8)4.5创建自定义命令栏 (8)4.6显示自定义命令栏 (8)4.7删除自定义命令栏 (9)4.8隐藏命令栏 (9)4.9显示命令栏 (9)4.10还原内置命令栏 (9)五、菜单 (10)5.1A DD方法用于C OMMAND B AR C ONTROLS对象 (10)5.2向命令栏添加自定义菜单控件 (11)5.3禁用命令栏上的菜单控件 (11)5.4启用命令栏上的菜单控件 (11)5.5删除命令栏上的菜单控件 (12)5.6还原命令栏上的菜单控件 (12)六、命令 (12)6.1向菜单控件添加分隔条 (13)6.2在菜单上创建自定义命令控件 (13)6.3在命令控件旁放置选中标记 (13)6.4禁用命令栏上的命令控件 (14)6.5启用命令栏上的命令控件 (14)6.6删除菜单上的命令控件 (15)6.7还原菜单上的内置命令控件 (15)七、子菜单 (15)7.1添加子菜单 (16)7.2向子菜单添加命令 (16)7.3禁用子菜单上的命令控件 (16)7.4删除子菜单上的命令 (17)7.5禁用子菜单控件 (17)7.6删除子菜单控件 (17)八、快捷菜单栏 (18)8.1新建快捷菜单栏 (18)九、快捷菜单 (19)9.1在快捷菜单栏上创建命令 (19)9.2禁用快捷菜单栏上的命令控件 (19)9.3删除快捷菜单栏上的命令 (20)9.4删除快捷菜单栏 (20)9.5还原内置快捷菜单栏上的命令 (20)十、快捷菜单上的子菜单 (20)10.1在快捷菜单栏上新建子菜单 (21)10.2在快捷菜单栏的子菜单上创建命令控件 (21)10.3禁用快捷菜单上的子菜单项控件 (22)10.4删除快捷菜单上的子菜单项控件 (22)10.5禁用快捷菜单上的子菜单控件 (22)10.6删除快捷菜单上的子菜单控件 (23)前言在EXCEL中,我们的操作都是通过“工具栏、菜单栏、快捷菜”单实现。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
利用VBA创建Excel新菜单.txt等余震的心情,就像初恋的少女等情人,既怕他不来,又怕他乱来。
听说女人如衣服,兄弟如手足,回想起来,我竟然七手八脚地裸奔了二十多年!今天心情不好,我只有四句话想说,包括这句和前面的两句,我的话说完了!利用VBA创建Excel 新菜单
使用VBA,可以很方便地向Excel菜单栏添加新菜单。
背景知识
1、菜单栏属于CommandBars集合,可以通过菜单栏名称或索引值对其进行引用:CommandBars(“Worksheet Menu Bar”)或CommandBars(1)
2、新添加的菜单是一个弹出式控件,其类型为msoControlPopup。
3、通过Add方法向Controls集合中添加新的控件。
Add方法可以指定控件的类型、内置控件的ID号、位置及是否是一个临时控件。
如果是一个临时控件,则在关闭Excel时会自动删除该菜单。
4、可以指定新菜单的位置。
如果不指定,则会在菜单工具栏末尾添加新菜单。
5、使用Caption属性指定新菜单的名称,使用OnAction属性指定单击菜单后的行为。
6、为了避免指定的菜单不存在,可以使用FindControl方法查找要指定的菜单。
若指定的菜单不存在,则在工作表菜单栏末尾添加新菜单。
添加菜单
向Excel工作表菜单栏中添加菜单的过程清单如下:
Sub AddNewMenu()
Dim HelpMenu As CommandBarControl
Dim NewMenu As CommandBarPopup
'利用ID属性查找帮助菜单
Set HelpMenu = CommandBars(1).FindControl(ID:=30010)
If HelpMenu Is Nothing Then
'如果该菜单不存在,则将新菜单添加到末尾
'设置新菜单为临时的
Set NewMenu = CommandBars(1).Controls _
.Add(Type:=msoControlPopup, Temporary:=True)
Else
'将新菜单添加到帮助菜单之前
Set NewMenu = CommandBars(1).Controls _
.Add(Type:=msoControlPopup, Before:=HelpMenu.Index, _
Temporary:=True)
End If
'添加标题并指定快捷键
NewMenu.Caption = "统计(&S)"
End Sub
运行该过程后,将在工作表菜单的“帮助”菜单左侧添加一个名为“统计”的新菜单。
注:要删除新添加的菜单,使用Delete方法即可,例如代码:
CommandBars(1).Controls("统计(&S)").Delete
将删除刚创建的“统计”菜单。
添加菜单项
与添加新菜单一样,在添加菜单项及子菜单时,使用Add方法,且指定合适的控件类型,其代码清单如下:
Sub AddNewMenu()
Dim HelpMenu As CommandBarControl
Dim NewMenu As CommandBarPopup
Dim MenuItem As CommandBarControl
Dim SubMenuItem As CommandBarButton
On Error Resume Next
'如果菜单已存在,则删除该菜单
CommandBars(1).Controls("统计(&S)").Delete
'利用ID属性查找帮助菜单
Set HelpMenu = CommandBars(1).FindControl(ID:=30010)
If HelpMenu Is Nothing Then
'如果该菜单不存在,则将新菜单添加到末尾
'设置新菜单为临时的
Set NewMenu = CommandBars(1).Controls _
.Add(Type:=msoControlPopup, Temporary:=True)
Else
'将新菜单添加到帮助菜单之前
Set NewMenu = CommandBars(1).Controls _
.Add(Type:=msoControlPopup, Before:=HelpMenu.Index, _
Temporary:=True)
End If
'添加菜单标题并指定热键
NewMenu.Caption = "统计(&S)"
'添加第一个菜单项
Set MenuItem = NewMenu.Controls.Add _
(Type:=msoControlButton)
With MenuItem
.Caption = "输入数据(&D)..."
.FaceId = 162
.OnAction = "Macro1"
End With
'添加第二个菜单项
Set MenuItem = NewMenu.Controls.Add _
(Type:=msoControlButton)
With MenuItem
.Caption = "汇总数据(&T)..."
'添加快捷键
.ShortcutText = "Ctrl+Shift+T"
.FaceId = 590
.OnAction = "Macro2"
End With
'添加第三个菜单项
'本菜单有子菜单项,因此其类型为msoControlPopup
Set MenuItem = NewMenu.Controls.Add _
(Type:=msoControlPopup)
With MenuItem
.Caption = "数据报表(&R)..."
'添加分隔线
.BeginGroup = True
End With
'添加子菜单
'添加第一个子菜单
Set SubMenuItem = MenuItem.Controls.Add _
(Type:=msoControlButton)
With SubMenuItem
.Caption = "月汇总(&M)"
.FaceId = 110
.OnAction = "Macro3"
End With
'添加第二个子菜单
Set SubMenuItem = MenuItem.Controls.Add _
(Type:=msoControlButton)
With SubMenuItem
.Caption = "季度汇总(&Q)"
.FaceId = 222
.OnAction = "Macro4"
End With
End Sub
注意,菜单类型的不同,有二个菜单项(类型为msoControlButton)、有一个菜单项带有子菜单(其类型为msoControlPopup)
FaceID属性确定出现在菜单文本旁边的图像,以数字表示,一个数字代表一个内置的图像。
在Caption属性中使用&号表示该菜单项的热键。
在第二个菜单项中,利用ShortcutText属性为该菜单项添加了一个快捷键,用户按此快捷键可以直接运行命令。
所添加的菜单如下图所示。