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

Excel事件(三)工作簿事件

一、工作簿事件基础 当发生工作簿更改,工作簿中的任何工作表更改,加载宏更改或数据透视表更改时,都可能引发对应的工作簿事件,合理地使用各个事件可以避免一些意料不到的错误,提高代码的可读性和执行效率。...二、工作簿事件分类 工作簿事件的种类很多,但很大一部分事件很难用到,下面图表列出工作簿事件和触发条件。可以收藏备查,根据需要来使用。...三、常见工作簿事件 1、open事件 打开工作簿时,将触发此事件,此事件中可以写入一些只需执行一次得代码。...比如打开工作簿时,如果用户始终按住shift键,是可以跳过open事件的。) 事件代码较简单,举个简单示例,比如打开工作簿时,选中固定的工作表。...比如activate事件中的所作的设置进行清理,恢复excel的初始设置等。这里就不举例说明了。

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

Excelize 发布 2.6.1 版本,支持工作簿加密

图片Excelize 是 Go 语言编写的用于操作 Office Excel 文档基础库,基于 ECMA-376,ISO/IEC 29500 国际标准。...可以使用它来读取、写入由 Microsoft Excel™ 2007 及以上版本创建的电子表格文档。...Go 语言最受欢迎的 Excel 文档基础库。...和 MaxCellStyles 以定义最小字号、最小列号和单元格样式数量上限公式引擎新增数组公式支持支持根据给定的密码对工作簿进行加密保护,相关 issue #199设置单元格富文本格式时,支持通过指定...#1264修复设置工作表视图属性时可能出现的 panic修复部分情况下因工作表核心属性中 dcterms 属性为空,导致生成的工作簿损坏问题修复新建工作表后工作簿属性丢失问题,解决 issue #1298

1.3K41

Excel-VBA复制工作表到新工作簿方法

工作中我们常常会在一个工作簿的一个工作表中输入数据,再另存为一个新的工作簿。 如:在文件“自动工具.xlsx”中有一个工作表为“模板”。...我想在“模板”工作表中输入数据,再另存为一个新的文件为“小龙女.xlsx” 【知识点】 下面是本个收藏的代码,三种方法,以备用 【代码】 '方法一:复制工作表另存为新的工作簿 Sub copySaveAs...,写入数据,再移动工作表另存为新的工作簿 Sub MoveSaveAs() wsh_num = Worksheets.Count Worksheets("模板").Copy After:...ActiveWorkbook.Worksheets(1).Name = "模板" ActiveWorkbook.Close SaveChanges:=True End Sub '方法三:新建工作簿...,再复制工作表到新工作簿中 Sub AddCopySaveAs() Path = ThisWorkbook.Path & "\" Set newwb = Workbooks.Add

9.4K40

Excel小技巧79:如何跟踪Excel工作簿的修改

Excel具有内置的跟踪功能,可以处理上述所有情况。你可以轻松地直接查看工作表上的所有更改,也可以接受或拒绝每个更改。关于Excel的跟踪功能,注意以下几点: 1....如果你对Excel工作表进行更改,然后在45天后再次打开该工作簿,则在关闭该工作簿之前,你将能够看到所有45天的更改历史记录。但关闭时,任何超过30天的更改历史记录都将消失。...无论何时开启跟踪,工作簿都将成为共享工作簿。这意味着多个用户将对文档进行更改。 上面是在Excel中如何进行跟踪的一些基本知识,接下来让我们来讨论如何启用它、更改设置和跟踪更改!...单击“修订”按钮左侧的“共享工作簿”按钮。弹出“共享工作簿”对话框,单击“高级”选项卡,如下图5所示。 ? 图5 在这里,你可以将保存更改历史记录的天数更改为30天以外的天数。...图6 单击“确定”按钮,将添加一个名为“历史记录”的工作表,让你查看对该工作簿所做的所有更改,如下图7所示。 ? 图7 在某个时候,你需要接受或拒绝更改。

5.9K30

Excel小技巧78:恢复未保存的Excel工作簿

excelperfect 我们可能碰到过这样的情形,正在编辑Excel工作簿时,Excel突然崩溃了(例如Excel老半天都没有响应)或者电脑突然断电了,这让我们来不及保存工作簿。...图1 这里有3个选项,可供你根据需要进行配置: 将文件保存为此格式:可以选择要将未保存的文件的保存的工作簿格式。 保存自动恢复时间间隔:可以设置自动保存文件的持续时间(以分钟为单位)。...除此之外,还有一个“自动恢复例外情况”选项,可以帮助恢复文件的最后未保存版本(保存一次)。 默认情况下,上述选项都已被激活,并将未保存的工作簿连续保存在你的系统上。...当你正在处理尚未保存到任何位置的文件时,Excel崩溃了或没有保存就将其关闭了,此时,重新打开Excel,单击Excel左上角“文件——打开”,再单击右侧的“最近”,接着单击右下方的“恢复未保存的工作簿...图5 此外,在Excel2010及以上的版本中,还可以重新恢复为工作簿以前的某个版本,可以在“文件——信息”下的“管理工作簿”中找到。 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。

1.9K00

Excel小技巧31:引用工作表或工作簿

excelperfect 在使用公式时,我们可以引用不同工作表甚至是不同工作簿中的单元格或单元格区域。其一般语法是: =工作表名!单元格区域 或者: =[工作簿名]工作表名!...A1+2 也可以引用不同工作簿中的单元格,例如下面的公式: =[test.xlsx]Sheet1!A1+5 引用工作簿test.xlsx中工作表Sheet1的单元格A1。...同样,如果工作簿名中包含一个或多个空格,则需要在工作簿工作表名前后加上单引号。例如公式: ='[mytest.xlsx]Sheet1'!...A1+5 如果想要从关闭的工作簿中取值,则必须使用完整路径的工作簿,例如: ='C:\[mytest.xlsx]Sheet1'!...A1+5 好习惯:如果要引用其他工作表或工作簿,无论其名称中是否包含空格,都在引用的工作表或工作簿名前后添加单引号,以确保万无一失。

1.6K20

快速合并多个CSV文件或Excel工作簿

标签:Power Query 合并多个CSV文件、文本文件、Excel工作簿等操作是我们日常工作中经常碰到的事,如果一个一个文件复制粘贴,费时费力又容易出错。...当然,可以使用VBA来解决,但前提是你必须懂VBA。这里有一个简单快速的方法,使用Power Query。...如果有一系列CSV文件,每个文件都包含着一名员工的信息,那么如何将这些文件中的员工信息合并到Excel中,Power Query能够帮助你快速完成。...图7 此时,这些CSV文件中的信息已合并至工作表中,如下图8所示。 图8 以后,当你更新了这些CSV文件的信息或者在该文件夹中添加了更多的CSV文件,只需简单地刷新查询即可实现信息更新。...当然,以上合并操作也适用于Excel文件,即快速合并多个工作簿中的工作表。

73740

Python操作Excel工作簿的示例代码(*.xlsx)

前言 Excel 作为流行的个人计算机数据处理软件,混迹于各个领域,在程序员这里也是常常被处理的对象,可以处理 Excel 格式文件的 Python 库还是挺多的,比如 xlrd、xlwt、xlutils...EXCEL文件 Excel 被称为电子表格,其实际可以保存的格式分为很多种,但是“Excel 工作簿(*.xlsx)”和“Excel 97-2003 工作簿(*.xls)”是其中比较常用的两种,可以认为...一般的 Excel 程序对于上述的两种格式都可以打开编辑,也可以相互转化存储,不过还是建议在没有特殊要求的情况下使用新版本的格式,一方面新的稳定版本可能会修复之前的一些BUG,同时也会带来进行一些优化。...Excel具体操作 关于使用 Python 具体操作 Excel 的方法可以分为三组,配合使用 xlrd、xlwt、xlutils 操作作为第一组,使用库 openpyxl 作为第二组,而 xlwings...xlrd、xlwt、xlutils 这一组操作 Excel 的库名字很形象,一个读、一个写、一个小工具,凑到一起就可以Excel 肆意妄为了,下面做个小练习,打开一个 Excel 文件然后修改第一个单元格的值

2.5K30

Excel Power Query学习:如何合并两个Excel工作簿

本文主要讲解如何使用Power Query以完全可审核、易于执行的方式解决合并两个工作簿的问题,主要是将两个工作簿工作表的数据放到一起。...示例数据 为了方便演示,准备了两个csv格式的示例文件,你可以在原网站下载,也可以到知识星球App完美Excel社群下载。...装载文件 打开一个新工作簿,单击功能区“数据”选项卡“获取和转换数据”组中的“获取数据——来自文件——从文本/CSV”,如下图1所示。...然后,可以通过在“查询设置”区域的属性名称中将其重命名,如下图8所示。 图8 单击功能区中的“关闭并上载”将其发送到Excel,如下图9所示。 图9 结果如下图10所示。...图10 我们可以看出,数据总共有4191行。那么,是不是加载了两个文件的全部数据呢?我们可以验证。一个简单方法是将hof_inducted和hof_not_inducred作为表加载到工作簿中。

1.8K20

Excel实战技巧89:强制用户保护工作簿工作

学习Excel技术,关注微信公众号: excelperfect 使用VBA代码,在用户关闭工作簿时,只有设置了保护工作簿,才能正常关闭。...如果单击“是”,则要先设置工作簿保护再关闭工作簿;如果单击“否”,则直接关闭工作簿。 ? 图1 上述代码提供给用户选择是否保护工作簿,下面的代码强制用户设置保护工作簿,否则不能关闭工作簿。...End If End Sub 同理,我们也可以使用代码来强制用户设置工作簿保护,否则不能关闭工作簿。...End If End Sub 上述代码是强制当前工作簿设置工作表保护,你也可以使用指定的工作表代替ActiveSheet,以强制必须对指定工作表设置保护,否则不能关闭工作簿。...欢迎到知识星球:完美Excel社群,进行技术交流和提问,获取更多电子资料。 ?

87430

Excel小技巧39:将工作簿藏起来

学习Excel技术,关注微信公众号: excelperfect 有时候,我们打开了多个工作簿。...我们不想关掉其中的一些工作簿,因为有可能会用到它,而这些工作簿可能来自不同的文件夹,也可能工作簿文件较大导致开启较慢,这样放在桌面上避免到处查找文件或者打开慢的影响,可供随时使用。...虽然说,我们可以按Alt+Tab组合键在不同的界面之间切换,但是如果打开的界面太多的话,这样也不方便。因此,我们可以隐藏一些不常用的工作簿。...此时,将隐藏该工作簿。而在切换不同界面时,这个隐藏的工作簿不会出现。 如果需要这个工作簿,则可以取消该工作簿隐藏。在功能区“视图”选项卡“窗口”组中单击“取消隐藏”命令,如下图2所示。 ?...欢迎关注[完美Excel]微信公众号

80210

Excel实战技巧78: 创建个人宏工作簿

个人宏工作簿是一个文件,可以在应用程序开启时运行其中的VBA代码,就像是运行功能区选项卡中的命令一样。创建个人宏工作簿很简单,如下所示。...图1 步骤2:在工作表中随便选取一个单元格,然后单击“开发工具”选项卡中的“停止录制”。 此时,Excel将自动创建个人宏工作簿文件。...图3 下面,我们将《Excel实战技巧77:实现在当前工作表和前一个使用的工作表之间自由切换》中创建的快捷键功能放到个人宏工作簿中,以便于在所有打开的工作簿中都能使用这个功能。...Private Sub Workbook_Open() Call TabBack_Run End Sub 保存并关闭Excel文件,然后随便打开一个工作簿,发现可以使用快捷键Alt+`在当前工作表和前一个工作表之间来回切换了...注意,因为个人宏工作簿中的功能可以应用到所有工作簿中,所以在编写代码时应使用ActiveWorkbook,而不是ThisWorkbook。

2.5K30

快速汇总多个工作簿工作表中的数据(Excel工具推荐)

这时候手头只有Excel,没有其他软件。最笨的办法是挨个打开这些工作簿,手动将数据源串联起来,然后做数据透视。可是 1.有时候数据源过大,超出单个Excel文件承载范围,你无法串联。...然后有一天我在ExcelHome论坛发现了版主写的一个神器,可以自动生成SQL语句,实现跨工作簿/工作表进行数据汇总透视。(点击阅读原文可以找到工具下载链接)下面介绍下该工具的使用方式。...可以看到 1.所有工作簿的所有工作表都显示在了左侧的列表里。这个时候我们可以选择部分工作簿/工作表进行汇总,也可以全选,看需求而定。此处我们全选。...3.可以看到有“插入工作簿名”,“插入工作表名”按钮,这两个按钮的意思是是否需要将工作簿/工作表的名称作为数据透视表的字段,此处我们假设想看各月的汇总情况,因此需要点击“插入工作簿名”。...我们可以看到这样多个工作簿/工作表的数据就汇总到一起了,Expr1000是工作簿名称字段,我们可以看到各个月的销售。

10.5K10

Excel VBA一键整理工资表,并进行分类新建工作簿加密

本代码一键完成工作,如下 我每一次下发工资表时,总会有一些我做表时的辅助行或列不要下发,这时我要删除; 有些内容要给谁不要给谁,要另存为新的工作簿; 最后我要进行加密下发。...本代码用的知识点有: VBA字典,用于查询 VBA新建工作簿并复制数据进去 if then语句,select case 语句 union方法 =========代码======= Sub delsh()...Application.ScreenUpdating = False dic("XXX") = "" arrA = Array("在职明细", "在职补发", "退休明细", "退休补发") ''''''设定要保留的工作表...col_a = "AA" ''''''''''设定要删除的,我的工作时的辅助列 row_a = 2308 col_b = "L" '''''''''设定要删除的,我的工作时的辅助列...ActiveWorkbook.Close True Rng.Delete ' Path = ActiveWorkbook.Path ' ActiveWorkbook.SaveAs Filename:=Path & "\加密下发

43720

Excel应用实践10:合并多个工作簿中的数据

学习Excel技术,关注微信公众号: excelperfect 这是ozgrid.com论坛中的一个问题贴子: 我有超过50个具有相同格式的Excel文件,它们的列标题相同,并且都放置在同一文件夹,有什么快速的方法将它们合并到一个单独的...Excel文件的一个工作表中?...假设工作簿文件结构如下图1所示。 ? 图1 其中,在文件夹“要合并的工作簿文件”中,有3个示例工作簿文件“测试1.xls、测试2.xls、测试3.xls”,将它们合并到工作簿“合并.xls”中。...As Variant response = MsgBox("想要运行合并程序?"...图4 导入到要合并的工作簿所在的文件夹,选择要合并的工作簿文件,单击“打开”按钮。如果一切顺利,则合并数据完成,并弹出如下图5所示的信息。 ? 图5 我们可以查看结果。

2.1K41

Excel应用实践21:实现工作簿所有工作表中的多值替换

学习Excel技术,关注微信公众号: excelperfect 有两个工作簿,一个工作簿中存放着要查找并替换成的文本,如下图1所示,列A中是要查找的文本,将列A中查找到的文本替换成列B中相应的文本,例如...,将找到的“Excel”替换成“完美Excel”。...图1 另一个工作簿中是我们要替换其文本的工作簿,我们要在该工作簿所有工作表中查找上图1列A中的值并将找到的文本替成列B中的文本,如图2所示。 ? 图2 要实现的结果如下图3所示。 ?...在图1所示的工作簿中,打开VBE,插入一个标准模块,输入代码: '查找并替换指定工作簿中的多个文本 Sub MultiFindReplace() Dim ReplaceListWB As Workbook...选择工作簿文件后,将根据上图1工作表中的文本自动对该工作簿中的文本进行查找和替换操作。 ? 图4 代码的图片版如下: ?

2.9K10

如何在前端应用中合并多个 Excel 工作簿

前言|问题背景 SpreadJS是纯前端的电子表格控件,可以轻松加载 Excel 工作簿中的数据并将它们呈现在前端浏览器应用的网页上。   ...在某些情况下,您可能需要将来自多个工作簿的数据(例如,来自不同部门的月度销售报告)合并到一个工作簿中,实现此目的的一种方法是使用多个隐藏的 SpreadJS 实例来加载所有工作簿,然后将它们合并到一个电子表格中...此文将向您展示如何合并多个 Excel 工作簿并将它们作为单个电子表格显示在您的前端浏览器应用中。 设置项目 要加载 SpreadJS,我们需要添加主要的 JavaScript 库和 CSS 文件。...文件 当用户准备好最终将所有工作簿合并为一个时,他们可以单击“合并工作簿”按钮,将每个工作簿中的每个工作表复制到页面上可见的 SpreadJS 实例: function MergeWorkbooks(...这显示在上面的函数中,可以添加到“spread.addNamedStyle()”。 添加该代码后,您现在可以加载多个 Excel 工作簿并使用 SpreadJS 将它们合并为一个。

19220
领券