网站首页 > 技术文章 正文
《VBA高级应用30例》(版权10178985),是我推出的第十套教程,教程是专门针对高级学员在学习VBA过程中提高路途上的案例展开,这套教程案例与理论结合,紧贴“实战”,并做“战术总结”,以便大家能很好的应用。教程的目的是要求大家在实际工作中分发VBA程序,写好的程序可以升级。
本套教程共三册三十个专题,VBA高级应用30例:Ribbon(功能区)的介绍
【分享成果,随喜正能量】 面对不擅长的事,不要死磕,接纳自己有力所不及的地方。接纳并理解生命的局限性,也正是因为有局限,我们才有了成长的空间,找到内心深处存在的匮乏和阻碍,遇到自己不擅长的事,不执着,不对抗,平和的接纳自己的短板,或是努力去弥补短板,或是乐观的承认短板的存在,有针对性的完善自己,调整自己,做真实愉悦自在的自己。。
应用1 在EXCEL中构建加载项
5 Ribbon(功能区)的介绍
在Office的发展历程中,07版之前的版本,我们称之为低版本,到07版及之后我们称之为高版本,低版本中的菜单命令栏结构存在诸多不便,这就导致了在高版本Ribbon的诞生。
对EXCEL及WORD比较熟悉的朋友知道:在Ribbon中将命令按逻辑分组,将最常使用的命令放到用户最容易看到的地方且以最醒目的方式显示,将以前深藏的或难以找到的功能移到了界面上,大大增强了命令的可访问程度;Ribbon始终固定在屏幕上方,不能随意定制,因而界面是固定的,不会因某些操作而造成混乱。如果要定制Ribbon,则需要编程或第三方工具,且需要理解XML及其规则。
一般来说,大多数用户只使用了软件20%的功能,而这20%的功能对于特定的用户来说可能又各自不同,在Excel 2003中,我们可以根据自已的喜好自定义菜单和工具栏,方便自已使用最常用的功能。在Excel 2007中,如果不使用RibbonX,则只能在快速访问工具栏(QAT)中添加自已常用的命令。
由于不能随意定制,因此命令不总是能按照某人所需要的顺序随意排列。有时,实现一项任务可能需要花时间单击不同的选项卡,使用不同组中的命令。
其实我们在高版本的office中也可以实现自定义Ribbon,只是只能在设计时,而不是在运行时,通常不能动态添加选项卡、组或控件。同时我们也很容易移除定制的Ribbon,只要文档中不包含定制Ribbon的代码,都将恢复默认的Ribbon界面。而不像以前版本的Office,自定义菜单和命令栏后难以恢复,尤其对于新用户。并且,除了加载项、全局模板外,在某文档中的Ribbon定制不会影响新文档的Ribbon。
6 自定义RibbonX(功能区)的实现
为了实现本专题加载项的要求我们要实现功能区的定制,这里我利用了一个Office RibbonX Editor的第三方软件来实现(这个软件会随教程提供),这里我只是列出实现本专题要求的代码部分,只是介绍,有兴趣的朋友可以通过其他途径学习。打开软件后,选择要自定义功能区的文件:
然后录入下面的代码:
<customUI xmlns="http://schemas.microsoft.com/office/2006/01/customui" onLoad="mynzSheetToolscustomUI_onLoad">
<ribbon>
<tabs>
<tab id="mynzSheetTools" label="工作表工具">
<group id="mynzSheetToolsGeneral" label="工作表工具">
<dropDown id="mynzSheetToolsbtnSheets"
getItemCount="mynzSheetToolsbtnSheets_Count"
getItemLabel="mynzSheetToolsbtnSheets_getItemLabel"
onAction="mynzSheetToolsbtnSheets_Click"
sizeString="MMMMMMMMM"
label="Sheets"
getSelectedItemIndex="mynzSheetToolsbtnSheets_getSelectedItemIndex"
/>
<button id="mynzSheetToolsbtnInsertToc"
label="Table Of Contents"
size="large"
onAction="mynzSheetToolsbtnInsertToc"
imageMso="CustomTableOfContentsGallery" />
</group>
</tab>
</tabs>
</ribbon>
</customUI>
代码截图:
最后保存。
代码的简单介绍:在这个xml中看到的项数是所谓的回调。这意味着Excel希望在相关工作簿中使用VBA代码。xml包含以下回调(callbacks):
① onLoad(加载工作簿时调用)
② getItemCount(返回下拉控件的项目数)
③ getItemLabel(获取下拉列表的第n个项目)
④ onAction(单击按钮或进行下拉选择时调用)
⑥ GetSelectEditedIndex(调用以获取下拉列表中需要选择的项)
- 在上述代码中有些复杂的过程名称(如“mynzpsheettoolsbtnssheets_Click”)。尤其是“mynzSheetTools”部分。在Excel实例中,回调名称必须是唯一的,是独一无二的。在Excel中打开的任何其他工作簿的子名称都不能与任何回调一致。否则,可能会导致其他工作簿中的例程被功能区调用!这就是为什么我在例程名称前面加上一些唯一标识包含RibbonX代码的工作簿前缀的原因。
我们要完成的各项任务罗列如下(这里只是罗列了任务,我们将在代码实现时填充代码):
Sub mynzSheetToolscustomUI_onLoad(ribbon As IRibbonUI)
End Sub
Sub mynzSheetToolsbtnInsertTOC(control As IRibbonControl)
End Sub
'Callback for mynzSheetToolsbtnSheets getItemCount
Sub mynzSheetToolsbtnSheets_Count(control As IRibbonControl, ByRef returnedVal)
End Sub
Public Sub mynzSheetToolsbtnSheets_getItemLabel(control As IRibbonControl, Index As Integer, ByRef returnedVal)
End Sub
'Callback for mynzSheetToolsbtnSheets getSelectedItemIndex
Sub mynzSheetToolsbtnSheets_getSelectedItemIndex(control As IRibbonControl, ByRef returnedVal)
End Sub
Sub mynzSheetToolsbtnSheets_Click(control As IRibbonControl, id As String, Index As Integer)
End Su
上面的代码将在功能区中添加一个“工作表工具”的任务,这个任务下面有一个选择工具和一个列表工具。
(待续)
我20多年的VBA实践经验,全部浓缩在下面的各个教程中:
猜你喜欢
- 2024-10-08 使用VBA自动化处理Excel数据生成装箱单
- 2024-10-08 补课了!VBA过程的附加技能(vba 过程调用)
- 2024-10-08 VBA三种程序类型介绍(vba程序是什么意思)
- 2024-10-08 Excel VBA 提取word表格信息(vba提取sheet名字)
- 2024-10-08 rust跟Excel vba交互(rust制作表)
- 2024-10-08 VBA|使用窗体控件02:使用显示信息的标签控件
- 2024-10-08 Excel破解:如何快速破解VBA窗口密码
- 2024-10-08 VB/VBA中的函数,用了那么久,其实是这样的
- 2024-10-08 VBA|正确使用过程和自定义函数(vba自定义函数参数说明)
- 2024-10-08 VBA如何自定义事件,一步一步教你学会
- 1509℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 534℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 496℃MySQL service启动脚本浅析(r12笔记第59天)
- 475℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 473℃启用MySQL查询缓存(mysql8.0查询缓存)
- 453℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 433℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 430℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)