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

Excel VBA解读(144): 使用Application事件和缓存将更快地获取已使用单元格区域

学习Excel技术,关注微信公众号: excelperfect 在上一篇文章中,建议加速检索已使用单元格区域最后一行方法之一是使用缓存和Application对象的AfterCalculate事件。...每行将在第1列(工作簿名称和工作表名称)中保存一个键,并在第2列中保存该工作簿中该工作表已使用单元格区域中的行数。假设只缓存包含这些用户自定义函数的前1000个工作表!...否则,查找已使用单元格区域中的行数,将其存储在UsedRange高速缓存的下一行中,并将其作为函数的结果返回。 该函数仅可在Excel 2007及更高版本中操作缓存。...有两个原因: 1.Excel 2003及更早版本最多有65536行,因此无论如何找到已使用单元格区域相对较快。...需要在每次计算后清空缓存,因为用户可能会改变已使用的单元格区域,因此安全的做法是在每次计算时重新创建缓存。AfterCalculate是一个应用程序级事件,在完成计算和相关查询和刷新后触发。

2.4K30

在Excel中使用VBA来自动化Word

本文演示的例子是,在Excel中使用VBA打开新的Word文档,复制Excel图表并粘贴到这个文档中。同时,介绍了一种你不熟悉Word VBA的情形下怎样获取相关的代码并在Excel中使用的方法。..., DocumentType:=0 Windows("在Excel中使用VBA自动化Word.docx").Activate End Sub 接着,回到Excel,打开VBE,单击菜单“工具——引用”...图1 这样,我们就使用了早期绑定来控制Word,也就可以在Excel VBE中使用如下声明代码: Dim WordApp As Word.Application Set WordApp = New Word.Application...在Word VBA中使用Documents.Add开始,在Excel VBA中修改为WordApp.Documents.Add,并且在VBA代码中通常不需要选择并激活对象,因此,修改后的代码如下: Sub...VBA打开应用程序时,通常是在后台打开,因此,要使Word文档可见,添加了下面的代码: WordApp.Visible = True 当然,在Excel中,也可以使用宏录制器录制代码,本示例中是复制工作表中的图表

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

    EXCEL中简单使用VBA上

    在Excel内部打开VBA 以及在运行之前需要开启一下家开发人员的安全性 打开的页面可能是这样,不要慌 可以在这里选择打开窗口 如果还是不一样,可以这这里打开资源的管理器 F4按键会按照当前你打开的窗口...,智能的打开你目前所在窗口的属性 我们按照惯例先看一下项目的管理栏目 首先好的一点就是可以看出来项目内部文件之间的层级关系 我们这里可以点击右键探索一些ssuo 在右键的菜单内可以打开菜单 我们这里看一下类...有两种排列模式,按照自己的喜好来选择使用 可以在后面的栏目内部打开还是开启此功能 这里是又绘制了一个窗口 未来后文的使用方便,可以重新定义一个文件 对于每一个将来要使用的事件,都可以去双击控件进入内部去编写触发用的代码...Label2_Click() End Sub Private Sub UserForm_Click() End Sub https://docs.microsoft.com/en-us/office/vba.../language/reference/user-interface-help/msgbox-constants 在微软的文档内可以查到对应使用的函数的一些参数以及用法 对于一些控件,我们可以成组的来控制

    1.8K10

    VBA通用代码:在Excel中创建弹出菜单

    标签:VBA,快捷菜单 弹出菜单(有时也称为上下文菜单或快捷菜单)是用户界面(UI)中的菜单,提供了一组命令选项,通过某些用户操作(如鼠标右键单击)在应用程序的当前状态或上下文中可用。...本文使用一种有效的技术创建在所有Excel版本中都可使用的弹出菜单。 注意,内置或自定义上下文菜单不同于弹出菜单的一种方式是,上下文菜单仅在右键单击鼠标时显示,而弹出菜单可以在需要时显示。...在VBE中,单击“插入——模块”,在标准模块中的代码如下: Public Const Mname As String ="MyPopUpMenu" Sub DeletePopUpMenu() '...End Sub 回到Excel界面,按Alt+F8键,调出“宏”对话框,选择“CreateDisplayPopUpMenu”宏,单击“选项”按钮,在“宏选项”对话框中的“快捷键”中输入字母m,如下图1所示...图1 这样,在Excel工作表中,按Ctrl+m组合键,会出现如下图2所示的弹出菜单。 图2 当单击菜单中的按钮时,会弹出一个信息框,如下图3所示。

    3.5K51

    使用VBA操作Excel公式栏

    标签:VBA 在Excel公式栏中,我们可以看到当前单元格中的内容,或者当前单元格中使用的公式,如下图1所示。 图1 我们也可以使用VBA来操作公式栏,作出一些变化。...通常我们会使用两个属性,一个是DisplayFormulaBar属性,用于设置是否显示/隐藏公式栏;一个是FormulaBarHeight属性,用于设置公式栏的高度。...下面我们列举两个示例来看看VBA是怎么操控公式栏的。 示例1:对指定列自动增加公式栏高度 当用户将当前单元格置于指定列时,公式栏自动增加高度。...例如,当前单元格位于列C时,公式栏会向下扩展,从而显示更多内容;位于其他列时,恢复原高度。...图2 示例2:对指定单元格隐藏公式栏 有时候,我们不想让用户直接看到我们所使用的公式,此时就可以在用户将单元格移到指定单元格时,隐藏公式栏。 例如,当用户将单元格移至列D时,隐藏公式栏。

    1.5K20

    VBA专题10-24:使用VBA操控Excel界面之单元格上下文菜单(Excel 2010及以后的版本)

    学习Excel技术,关注微信公众号: excelperfect 添加按钮控件 假设你需要对工作表中前面有货币符号的值执行计算,然而那些值被解释为文本,你要编写VBA过程来移除所选单元格区域中的货币符号。...添加其他类型的控件 除了上面介绍的使用XML代码在单元格上下文菜单中添加按钮控件外,还可以添加6种其他类型的内置控件和自定义控件:切换按钮、拆分按钮、菜单、库、复选框和动态菜单。...《VBA专题10-23:使用VBA操控Excel界面之添加动态菜单》一文中,当用户激活不同的工作表时,在Workbook_SheetActivate事件处理中明确地使菜单无效(为了重新构建菜单)。...然而,如果动态菜单在单元格上下文菜单中,那么不需要编写VBA代码来使菜单无效。当用户右击工作表单元格时,动态菜单在单元格上下文菜单显示其内容的过程中重新创建。...下图展示了含有不同类型的(自定义和内置的)控件的单元格上下文菜单: 640 (1).gif 注意,无法将控件添加到Excel 2007中的单元格上下文菜单和更早的XML代码中。

    1.6K10

    Excel小技巧24:在单元格中插入特殊字符

    在有些工作表中,我们能够看到如下图1所示的图形字符。 ? 图1 这是怎么实现的呢?其实,这都归功于我们常用的“符号”对话框及字符设置。使用这个对话框,我们可以在单元格中插入特殊字符。...以插入笑脸符号为例: 1.单击功能区“插入”选项卡中的“符号”按钮。 2.在弹出的“符号”对话框中,在字符下拉列表中选择“Wingdings”字体,然后在其下面找出笑脸符号,如下图2所示。 ?...图2 3.单击“确定”按钮,将笑脸符号插入到当前单元格中。 从图2所示的“字符”对话框中,我们可以看到笑脸符号字符的代码是74。这样,也可以使用CHAR函数并结合字体设置来得到笑脸符号。...1.在单元格中输入公式:=CHAR(74),如下图3所示。可以看出,单元格中显示的是字符“J”。 ? 图3 2.选择该单元格,设置其字体为“Wingdings”,如下图4所示。...可以看到,单元格中变成了笑脸字符。 ? 图4 实际上,选择不同的字符,我们可以得到一些不同的特殊字符符号,如下图5所示,这是我们选择了“Webdings”字体后得到的一些字符符号。 ?

    2.6K40

    不使用VBA,添加图片到单元格

    标签:Excel技巧 有时候,我们想在单元格中显示图片,然而又不想使用VBA,该怎么办呢?有一种方法,就是使用单元格批注。...可以将图片添加到单元格批注中,这样,用户鼠标在该单元格上时,就会显示图片,无需VBA,非常简单,如下图1所示。 图1 下面讲解实现步骤。...步骤1:在单元格中单击右键,从快捷菜单中选择“插入批注”命令,如下图2所示。 图2 步骤2:选择批注,单击右键,从快捷菜单中选择“设置批注格式”命令,如下图3所示。...图3 步骤3:在“设置批注格式”对话框中,选择“颜色与线条”选项卡,单击“颜色”下拉框,从中选择“填充效果”命令,如下图4所示。...图4 步骤4:在“填充效果”对话框中,选择“图片”选项卡,单击“选择图片”按钮,如下图5所示。 图5 步骤5:在下图6所示的对话框中,选择从哪里选取要插入的图片。

    69930

    从Python中运行Excel VBA

    有时候,我们可能想要从Python运行Excel VBA宏,特别是当想要运行已有的Excel宏时,这很有用——甚至可以在不打开Excel文件的情况下执行这些VBA宏。...Excel VBA宏 下面是一个非常简单的Excel VBA宏,它接受一个参数,在工作表Sheet1的单元格B2中输入一条问候语。...End Sub 从Python中运行VBA宏 现在,将编写Python代码,从导入win32com.client开始,并实例化一个“xl”对象来表示Microsoft Excel应用程序。...模块1.mymacro("完美Excel")') wb.Save() xl.Application.Quit() 为了调用VBA宏,使用了xl.Application.Run()方法,其中的参数指示要运行的宏...模块1.mymacro') 接下来,使用wb.Save()保存这个Excel文件,也可以选择使用VBA代码来保存这个工作簿。

    5.7K20

    Excel VBA解读(140): 从调用单元格中获取先前计算的值

    学习Excel技术,关注微信公众号: excelperfect 如果有一个依赖于一些计算慢的资源的用户定义函数,可能希望该用户定义函数在大多数情况下只返回其占用的单元格中最后一次计算得到的值,并且只偶尔使用计算慢的资源...可以设置开关(这里使用称为“RefreshSlow”的已定义名称)并在VBA过程中刷新用户定义函数,如下所示: Sub RefreshUDFs() Dim lCalcMode As Long...Application.Caller.Text,则不会获得循环引用,但会检索单元格中显示为字符串的格式化值。...(命令等效函数默认为易失性,但在使用它将前一个值传递给VBA用户定义函数时,通常希望它是非易失性的)。此函数也适用于多单元格数组公式。...小结 有几种方法可以从VBA用户定义函数的最后一次计算中获取先前的值,但最好的解决方案需要使用C++ XLL。

    6.8K20
    领券