小编Mic*_*Mic的帖子

VB:将范围复制到另一个Excel应用程序

我试图解决一个相对简单的问题,但我无法实现.我的目标是将主Excel应用程序的工作表中的一系列单元格复制到第二个新创建的Excel应用程序的工作表中的另一个范围(相同大小).我使用创建第二个应用程序

Set secondExApp = CreateObject("Excel.Application")
Run Code Online (Sandbox Code Playgroud)

我正在使用此参考资料进行进一步处理.到现在为止,我尝试了两种不同的方法.两者都不能正常工作.

0:准备/介绍

Set srcWb = Application.ActiveWorkbook
Set srcSheet = srcWb.Worksheets("example")

Set dstApp = CreateObject("Excel.Application")
Set dstWb = dstApp.Workbooks(1)
Set dstSheet = dstWb.Worksheets(1)
Run Code Online (Sandbox Code Playgroud)

1:PasteSpecial - 提供图像(!)而不仅仅是范围

srcSheet.Range("A1:B2").Copy
dstSheet.Range("A1:B2").PasteSpecial xlPasteAll
Run Code Online (Sandbox Code Playgroud)

2:Range.Copy [Destination] - 不起作用 - 我是否只能在同一个应用程序中使用此方法?

srcSheet.Range(srcSheet.Cells(..., ...), srcSheet.Cells(..., ...)).Copy _
dstSheet.Range(dstSheet.Cells(..., ...), dstSheet.Cells(..., ...))
Run Code Online (Sandbox Code Playgroud)

任何帮助表示赞赏.


编辑:我已经玩过"记录宏"功能,但我更喜欢自己编码而不"选择"或"激活"单元格/表格等.


编辑(已解决):非常感谢GSerg和iDevlop,你为我提供了一个很好的起点.就Excel的常数xlClipboardFormatDspText而言,我做了一些研究.

真正帮助我的是打开一个新的Excel实例更改了粘贴(特殊)菜单.

因此,我现在只需添加一个工作簿(可以隐藏)并使用此对象添加我的内容,而不是创建新实例.由于它保存在同一个实例中(也可以查看任务管理器),因此粘贴(特殊)菜单完全相同.

现在即使没有选择也可以使用Range.Copy [destination]!

结果:

'Hides the new workbook
Application.ScreenUpdating = False

Set dstWb = Workbooks.Add
Set dstSheet = dstWb.Worksheets(1) …
Run Code Online (Sandbox Code Playgroud)

excel vba range

5
推荐指数
1
解决办法
5308
查看次数

标签 统计

excel ×1

range ×1

vba ×1