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

将宏放在单独的工作簿中以定位工作簿,将工作表中的值复制并粘贴到新工作簿中,并保存到原始工作簿的位置

宏(Macro)是一种用于自动化执行任务的代码片段。在Excel中,宏可以用于执行各种操作,例如复制、粘贴、格式化等。下面是一种实现将工作表中的值复制并粘贴到新工作簿中,并保存到原始工作簿位置的方法:

  1. 打开Excel,并打开包含要操作的工作表的工作簿。
  2. 按下Alt + F11,打开Visual Basic for Applications(VBA)编辑器。
  3. 在VBA编辑器中,选择插入(Insert)-> 模块(Module),创建一个新的模块。
  4. 在新的模块中,编写以下VBA代码:
代码语言:vba
复制
Sub CopySheetToNewWorkbook()
    Dim newWorkbook As Workbook
    Dim currentWorkbook As Workbook
    Dim currentSheet As Worksheet
    
    ' 创建一个新的工作簿
    Set newWorkbook = Workbooks.Add
    
    ' 获取当前工作簿的引用
    Set currentWorkbook = ThisWorkbook
    
    ' 获取当前工作表的引用
    Set currentSheet = currentWorkbook.ActiveSheet
    
    ' 将当前工作表的值复制到新工作簿中
    currentSheet.Copy Before:=newWorkbook.Sheets(1)
    
    ' 关闭新工作簿的其他工作表
    Do While newWorkbook.Sheets.Count > 1
        newWorkbook.Sheets(newWorkbook.Sheets.Count).Delete
    Loop
    
    ' 保存新工作簿到原始工作簿的位置
    newWorkbook.SaveAs currentWorkbook.Path & "\" & "新工作簿名称.xlsx"
    
    ' 关闭新工作簿
    newWorkbook.Close
    
    ' 清理对象引用
    Set newWorkbook = Nothing
    Set currentWorkbook = Nothing
    Set currentSheet = Nothing
End Sub
  1. 关闭VBA编辑器。
  2. 在Excel中,按下Alt + F8,打开宏对话框。
  3. 选择刚刚创建的宏(CopySheetToNewWorkbook),并点击运行。

这样,宏将会在单独的工作簿中创建一个新的工作表,并将原始工作表的值复制到新工作表中。然后,新工作簿将保存在原始工作簿的位置。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云对象存储(COS):提供高可靠、低成本的云端存储服务,适用于图片、音视频、文档等各类数据的存储和管理。详情请参考:https://cloud.tencent.com/product/cos
  • 腾讯云云服务器(CVM):提供弹性计算能力,支持按需购买、弹性扩容、自定义配置等特性,适用于各类应用的部署和运行。详情请参考:https://cloud.tencent.com/product/cvm
  • 腾讯云数据库(TencentDB):提供多种类型的数据库服务,包括关系型数据库、NoSQL数据库等,适用于各类应用的数据存储和管理。详情请参考:https://cloud.tencent.com/product/cdb
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • EXCEL VBA语句集300

    定制模块行为 (1) Option Explicit ‘强制对模块内所有变量进行声明 Option Private Module ‘标记模块为私有,仅对同一工程中其它模块有用,在宏对话框中不显示  Option Compare Text ‘字符串不区分大小写  Option Base 1 ‘指定数组的第一个下标为1 (2) On Error Resume Next ‘忽略错误继续执行VBA代码,避免出现错误消息 (3) On Error GoTo ErrorHandler ‘当错误发生时跳转到过程中的某个位置 (4) On Error GoTo 0 ‘恢复正常的错误提示 (5) Application.DisplayAlerts=False ‘在程序执行过程中使出现的警告框不显示 (6) Application.ScreenUpdating=False ‘关闭屏幕刷新 Application.ScreenUpdating=True ‘打开屏幕刷新 (7) Application.Enable.CancelKey=xlDisabled ‘禁用Ctrl+Break中止宏运行的功能  工作簿 (8) Workbooks.Add() ‘创建一个新的工作簿 (9) Workbooks(“book1.xls”).Activate ‘激活名为book1的工作簿 (10) ThisWorkbook.Save ‘保存工作簿 (11) ThisWorkbook.close ‘关闭当前工作簿 (12) ActiveWorkbook.Sheets.Count ‘获取活动工作薄中工作表数 (13) ActiveWorkbook.name ‘返回活动工作薄的名称 (14) ThisWorkbook.Name ‘返回当前工作簿名称 ThisWorkbook.FullName ‘返回当前工作簿路径和名称 (15) ActiveWindow.EnableResize=False ‘禁止调整活动工作簿的大小 (16) Application.Window.Arrange xlArrangeStyleTiled ‘将工作簿以平铺方式排列 (17) ActiveWorkbook.WindowState=xlMaximized ‘将当前工作簿最大化  工作表 (18) ActiveSheet.UsedRange.Rows.Count ‘当前工作表中已使用的行数 (19) Rows.Count ‘获取工作表的行数(注:考虑向前兼容性) (20) Sheets(Sheet1).Name= “Sum” ‘将Sheet1命名为Sum (21) ThisWorkbook.Sheets.Add Before:=Worksheets(1) ‘添加一个新工作表在第一工作表前 (22) ActiveSheet.Move After:=ActiveWorkbook. _ Sheets(ActiveWorkbook.Sheets.Count) ‘将当前工作表移至工作表的最后 (23) Worksheets(Array(“sheet1”,”sheet2”)).Select ‘同时选择工作表1和工作表2 (24) Sheets(“sheet1”).Delete或 Sheets(1).Delete ‘删除工作表1 (25) ActiveWorkbook.Sheets(i).Name ‘获取工作表i的名称 (26) ActiveWindow.DisplayGridlines=Not ActiveWindow.DisplayGridlines ‘切换工作表中的网格线显示,这种方法也可以用在其它方面进行相互切换,即相当于开关按钮 (27) ActiveWindow.DisplayHeadings=Not ActiveWindow.DisplayHeadings ‘切换工作表中的行列边框显示 (28) ActiveSheet.UsedRange.FormatConditions.Delete ‘删除当前工作表中所有的条件格式 (29) Cells.Hyperlinks.Delete ‘取消当前工作表所有超链接 (30) ActiveSheet.PageSetup.Orientation=xlLandscape 或ActiveSheet.PageSetup.Orientation=2 ‘将页面设置更改为横向 (31) ActiveSheet.PageSetup.RightFooter=ActiveWorkbook.FullName ‘在页面设置的表尾中输入文件路径 ActiveSheet.PageSetup.Le

    04

    (ExcelVBA编程入门范例)

    很喜爱VBA,喜欢使用她对Excel操作实现所需的功能,更喜欢使用VBA控制Excel以及实现结果后的那种感觉。 一直都想对ExcelVBA进行系统的整理和归纳,但由于对Excel及VBA了解得不够深入,总觉得无从下手。再加上又是利用少得可怜的业余时间进行学习,时断时续,学习的主线和思路也经常因为工作或其它的事情而打断。但喜欢学习的人总会挤得出时间来的,要想掌握或者是精通一门知识和技术不能有任何借口。幸运的是,有网络这个大平台,更有ExcelHome众多网友的帮助和鼓励,这几个月,总算坚持了下来。对Excel的痴迷没有停留在头脑和心中,而是体现在了具体的行动以及积极的学习和参与上来,因此,收获很大,感觉水平也有明显的提高。 现在,我计划利用点滴的业余时间,将基本的ExcelVBA操作用简短的实例进行演示,编辑成《ExcelVBA编程入门范例》,以此对ExcelVBA基础知识进行一次归纳和整理,从而理清学习ExcelVBA的线条,同时也希望能对热衷于Excel的朋友以及ExcelVBA初学者快速了解和步入ExcelVBA编程殿堂有所帮助。这是我第一次偿试对所学知识进行较大规模的整理,希望大家能多提改进意见和建议,以利于改进和提高,也有助于以后的学习和编写出更好的作品呈献给大家。

    02
    领券