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

VBA代码:拆分工作簿示例——将工作簿中的每个工作表保存为单独的工作簿

标签:VBA 有时候,我们想将工作簿中的每个工作表都保存为一个单独的工作簿。 你可以使用下面的操作逐个保存工作表: 1.在工作表标签中单击右键。 2.选取“移动或复制…”命令。...3.选择“(新工作簿)”。 4.保存该工作簿。 图1 这样,有多少工作表,你就要操作上面的步骤多少次。 然而,如果存在很多个工作簿,这样的重复工作使用VBA是最合适的。...msoFileDialogFolderPicker) .InitialFileName =Application.DefaultFilePath & "\" .Title = "选择保存工作表的位置...Next wks Application.ScreenUpdating = True Application.DisplayAlerts = True End Sub 只需在要拆分的工作簿中运行上述代码...,就可将该工作簿中的所有工作表全部保存为单独的工作簿。

4.1K11

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

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

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

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

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

    11.6K40

    VBA专题10-20:使用VBA操控Excel界面之隐藏和取消隐藏控件、组和选项卡

    例如,下面的示例XML代码和在标准VBA模块中的代码在运行时满足某条件时隐藏(和取消隐藏)“对齐方式”组: ? customUI元素包括带有Initialize回调过程的onLoad属性。...在Custom UI Editor中保存该文件,首次在Excel中打开时,会出现关于Initialize和HideAlignmentGroup过程的错误消息提示,因为这两个过程仍然没有在标准的VBA模块中找到...如果活动工作表不是标准工作表,就隐藏该组,否则该组可见。 注意,当打开工作簿时,创建ribbon对象。编辑VBA代码可能销毁这个新创建的对象。...试图使与销毁对象相关的控件无效是不可能的,唯一的办法是重新创建ribbon对象重新打开该工作簿。 当激活图表工作表时,“开始”选项卡中的“对齐方式”组被隐藏,如下图所示: ?...与隐藏(和取消隐藏)内置组相似,可以在运行时当满足某条件时动态地隐藏(和取消隐藏)内置选项卡。例如,运行时当满足某条件时,下面的示例XML代码和VBA代码可以隐藏(和取消隐藏)“开始”选项卡: ?

    8.1K20

    VBA实用小程序62: 获取文件夹中最新保存的工作簿

    在有些情形下,我们可能需要找到指定文件夹中最新保存的工作簿,然后对其进行处理。...例如,每天上班前系统会自动生成一个工作簿并保存到某文件夹中,而某位员工每天上班后需要从该文件夹中打开这个新生成的工作簿来提取数据,这样程序需要根据工作簿保存的时间找到这个最新保存的工作簿,然后再对其进行处理...下面的程序可以返回指定文件夹中最新保存的工作簿名称: '获取指定文件夹中除当前工作簿外 '最新保存的工作簿的文件名 Function GetLastWorkbook(sPath As String) As...Do While sFile "" Set objFile = fs.GetFile(sPath &sFile) '如果文件不是本代码所在的工作簿且文件最近保存的日期大于上一文件保存的日期...'下一个文件 sFile = Dir Loop '返回值 GetLastWorkbook = sName End Function 假设当前工作簿存放在指定要获取最新保存工作簿的文件夹中

    1.5K10

    探索VBA代码编辑器——《Excel VBA宏编程》系列讲座2

    Excel已经为我们准备好了编写VBA代码的编辑器,让我们非常方便地编写、运行和调试、保存VBA代码。...其中VBAProject是根节点,默认带有一个Excel对象,其中包含代表当前工作簿的ThisWorkbook对象模块和工作表Sheet1对象模块。...图5 从中我们对Excel VBA中非常重要的概念进行初步理解:工作簿是一个可以引用的对象,每个工作表也是一个可以引用的对象。...切换到Excel界面,新建一个工作表,你会看到弹出一个带有“HelloWorld!”的消息框,如下图11所示。 图11 同样,双击工作表代码模块,进入工作表代码窗口。...图12 保存包含VBA代码的工作簿 在保存含有VBA代码的工作簿时,我们需要使用xlsm扩展名,如下图13所示,否则Excel会自动删除代码。

    3.8K20

    VBA实战技巧:正确登录后才能使用Excel工作簿

    当你打开这个工作簿时,Excel会弹出一个登录框,如下图1所示。当你输入正确的用户名和密码后,才能使用这个工作簿,否则会退出。...图1 这个工作簿中有一个名为“用户中心”的工作表,用来存放用户名、密码等信息,如下图2所示。 图2 打开VBE,插入一个用户窗体,在其中放置标签、文本框、按钮等控件,并将相关控件命名。...= xlDisabled Sheets("数据").Activate Sheets("用户中心").Visible= xlVeryHidden login.Show End Sub 关闭工作簿...,重新打开,会弹出上图1所示的登录窗口。...注:建议你动手按照文中的介绍实现图1所示的效果。当然,如果想下载示例工作簿,请到知识星球完美Excel社群中下载。 欢迎在下面留言,完善本文内容,让更多的人学到更完美的知识。

    1.2K20

    matinal:Excel用VBA代码一键合并汇总多个工作簿

    有时候,你需要将几十个工作簿中的内容,快速汇总至合并至一个工作簿,如果手动一个复制粘贴,那心里有苦说不出。。。...今天将大家用VBA一键合并,只需要几秒种,为了测试这段代码,我们新建了4个工作簿在文件夹中,数据都是模拟的,做试验 一键合并代码操作如下所示: 我们看原始表格数据,其中,第1个工作簿有点特殊,这个工作簿中...,有两个工作表,第1个工作表的内容是: 第2个工作表的内容是: 第2,3,4个工作簿中都是仅有1个工作表,如下所示: 通过代码,我们一键可以合并,得到结果,这个汇总的结果有两个特点 1、最后一列,还会显示这些数据的来源是哪个工作簿...2、原始数据中每一行的标题自动取消,只保留了一个标题。...如下所示: 在Excel菜单栏中,点击开发工具,打开VBA,输入如下代码: 其中代码如下所示: Sub 合并目录所有工作簿全部工作表() Dim MP, MN, AW, Wbn, wn Dim Wb

    1K50

    VBA专题10-4:使用VBA操控Excel界面之设置工作簿视图和窗口

    下面是设置工作簿视图和窗口的一些VBA代码。 工作簿视图 可以选择使用普通视图、页面布局视图、分页预览视图来显示工作表。...普通视图 示例代码: '以普通视图显示活动窗口中的活动工作表 ActiveWindow.View = xlNormalView 分页预览 示例代码: '以分页预览显示活动窗口中的活动工作表 ActiveWindow.View...,那么上述语句执行时会导致运行时错误,因为图表工作表、宏工作表或对话框工作表没有这些视图选项。...'取消冻结窗格 With ActiveWindow .FreezePanes = False '如果删除了拆分窗格,也需要下列代码行 '因为ActiveWindow对象的Split...属性可能初始化为True .Split = False End With 说明:本专题系列大部分内容学习整理自《Dissectand Learn Excel VBA in 24 Hours:Changingworkbook

    3.8K20

    Excel实战技巧57: 标识并使用VBA代码识别特定的工作簿

    一种常用的方法是对工作簿文件添加自定义的文档属性,这样让代码在不打开工作簿的情况下判断是否是想要的工作簿。...为工作簿添加自定义文档属性 单击“文件——信息——属性——高级属性”,打开工作簿的“属性”对话框。...选取“自定义”选项卡,在名称文本框中输入属性名称,示例中是“MyTestBook”,在类型下拉列表中选择“是或否”,选取取值选项按钮中的“是”,单击“添加”按钮,如下图1所示,为该工作簿添加自定义文档属性...,测试工作簿中是否具有名为MyTestBook的属性,如果是,则弹出下图3所示的消息。...End If Next i End Sub 如果所选工作簿具有指定的属性,则弹出下图3所示的消息。 ?

    1.8K10

    Excel实战技巧64: 从工作簿中获取数据(不使用VBA)

    这是在研读《Escape From Excel Hell》时学到的技术,从本工作簿中或者其他工作簿中获取所需要的数据,以便于作进一步的分析或者绘制Excel图表。 下图1所示是用于获取数据的工作表。...用于输入的有4个单元格(背景色为橙色),其中单元格A6中输入源数据(即要从哪里获取数据)所在的工作簿名称;单元格A7中为源数据所在的工作表名称;单元格A8中为源数据起始单元格的名称;单元格C5中为数据所在列号...其中,SourceDataLocation为源数据工作表中数据所在区域的起始单元格名称。在本示例工作簿中,该单元格位置如下图2所示。 ?...如果在图1所示的工作表单元格A6中没有输入任何工作簿名(即留空),那么将获取当前工作簿中源数据工作表(如图2)的数据,如下图3所示。 ?...可以在完美Excel微信公众号底部发送消息: 获取数据 下载示例工作簿研究。

    3.1K10

    VBA专题10-9:使用VBA操控Excel界面之在功能区中添加自定义按钮控件

    添加按钮 如果要在内置功能区选项卡中添加两个按钮,在单击这些按钮时会调用VBA过程,那么执行下面的步骤: 1. 创建新工作簿并保存为启用宏的工作簿。 2....关闭该工作簿,然后在CustomUI Editor中打开该工作簿。 3. 在CustomUI Editor中,单击“插入”并选择“Office 2007 Custom UI Part”。 4....带有Mso图像0和1)的标记为Attn Sh的组。...之后,要将其粘贴到工作簿的VBA模块中。 7. 保存并关闭该文件。 8. 在Excel中打开该工作簿文件。 9. 按Alt+F11键打开VBE。 10....说明:本专题系列大部分内容学习整理自《Dissectand Learn Excel VBA in 24 Hours:Changingworkbook appearance》,仅供学习研究。

    5.2K30

    VBA专题10-10:使用VBA操控Excel界面之在功能区中添加自定义切换按钮控件

    excelperfect 添加的步骤与本系列上一篇文章《VBA专题10-9:使用VBA操控Excel界面之在功能区中添加自定义按钮控件》中的步骤相同,即:新建一个启用宏的工作簿并保存,关闭该工作簿,然后在...CustomUI Editor中打开该工作簿,输入下面的XML代码: ?...重新打开该工作簿后,在“Custom”选项卡中显示含两个切换按钮的组,如图1所示。我们看到,一个按钮带有标签,一个没有标签。可以对照XML代码看看自定义的界面是怎么创建的。 ?...Sub 单击自定义的按钮,会根据按钮是否被按下,弹出下图2所示的信息框,这是切换按钮被按下时显示的信息。...图2 说明:本专题系列大部分内容学习整理自《Dissectand Learn Excel VBA in 24 Hours:Changingworkbook appearance》,仅供学习研究。

    1.8K10

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

    如果你对Excel工作表进行更改,然后在45天后再次打开该工作簿,则在关闭该工作簿之前,你将能够看到所有45天的更改历史记录。但关闭时,任何超过30天的更改历史记录都将消失。...这意味着下次打开它时,你将无法看到45天前所做的更改。 4. 无论何时开启跟踪,工作簿都将成为共享工作簿。这意味着多个用户将对文档进行更改。...“位置”选项允许你仅跟踪电子表格特定部分的更改。只需单击右侧的按钮,然后选择要跟踪的单元格范围。 最后,如果你不想让其他人知道你正在跟踪更改,可以取消选中“在屏幕上突出显示修订”选项。...如果取消选中“在屏幕上突出显示修订”选项,则不会显示黑色小三角形。 ?...单击“修订”按钮左侧的“共享工作簿”按钮。弹出“共享工作簿”对话框,单击“高级”选项卡,如下图5所示。 ? 图5 在这里,你可以将保存更改历史记录的天数更改为30天以外的天数。

    6.6K30

    隐藏工作簿中所有工作表的行列标题,VBA一次搞定

    标签:VBA 有时候,我们不需要看到工作表中的行列标题,如下图1所示。 图1 此时,可以修改Excel设置来实现。...单击“文件——选项”,在“Excel选项”对话框中,单击左侧的“高级”选项卡,在“此工作表的显示选项”中取消选取“显示行和列标题”前的勾选,如下图2所示。...图2 可以看出,这个设置只对指定的工作表有效,如果要隐藏工作簿中所有工作表的行列标题,则要逐个选择工作表,并取消该选项的选择。 如果工作簿中有很多工作表,这样的重复操作就有点浪费时间了。...下面的代码隐藏工作簿中除指定工作表外的所有工作表的行列标题: Sub HideHeadings() Dim wks As Worksheet Application.ScreenUpdating...= False '遍历工作簿中的工作表 For Each wks In ThisWorkbook.Worksheets '名为"示例"的工作表除外 '你可以修改为自己的工作表名

    2K20

    运行Excel VBA的15种方法2

    标签:VBA 本文接上一篇:运行Excel VBA的15种方法1 方法8:自定义功能区 可以自定义功能区,将宏代码关联到功能区选项卡组中。这种方法尤其适合于组织布置许多自定义宏的运行。...图16 此时,会在功能区中添加带有一个组的自定义选项卡。选择该选项卡,单击“重命名”按钮,修改默认的名称,如下图17所示。...图18 单击“确定”,这样就在Excel功能区中添加了一个名为“我的宏代码”的自定义选项卡,带有一个“新建组”,里面是与要运行的宏关联的命令按钮,如下图19所示。...方法14:从超链接中运行VBA 单击超链接时触发宏运行,如下图23所示。 图23 很特别! 方法15:从工作簿事件中调用VBA过程 基于工作簿事件,例如打开或关闭工作簿时自动运行宏。...图24 你还知道有什么运行Excel VBA的方法吗?

    54840

    VBA: 将多个工作簿的第一张工作表合并到一个工作簿中

    一般的操作方法是打开两个工作簿(目标工作簿和待转移的工作簿),然后选中需要移动的工作表,右键单击以后选择“移动或复制”。接下来在新的对话框里面进行设置。 这种方法适合在移动少量工作表的时候使用。...如果有很多的工作簿,都需要进行移动的话,一个一个打开然后再操作比较费时费力。这时就可以使用VBA来批量进行操作。...在目标工作簿内,插入一个模块,然后导入如下的代码: Option Explicit Sub MergeWorkbook() '将多个工作簿的第一张工作表合并到目标工作簿中...End Sub (1) 将目标工作簿和待转移的工作簿放在同一个文件夹内; (2)上述代码要实现的功能是,将同一个文件夹内所有工作簿(目标工作簿除外)的第一张工作表拷贝到目标工作簿内,并将表名设置为拷贝前所属的工作簿名称...转移前: 转移后: 参考资料: [1] 如何使用Excel VBA将多个工作簿的全部工作表合并到一个工作簿中(https://zhuanlan.zhihu.com/p/76786888)

    6.1K11
    领券