如何在关闭工作簿时禁用 Excel VBA 中的剪贴板提示?

SRo*_*Roy 4 excel clipboard vba

因此,我正在使用多个工作簿,将每个工作簿中 Sheet1 中的所有数据复制到主工作簿上各自的工作表中。完成此操作后,我将多个工作簿编码为关闭。但是,会弹出一个烦人的提示,询问我是否要始终将复制的数据保留在剪贴板上,我想让它不弹出,或者当它弹出时,我希望自动选择“否”。

我知道有人问过类似的问题,但它对我不起作用,我想这是因为我有一个矩形的数据区域而不仅仅是一列?我对 vba 确实很陌生,但我尝试在工作簿关闭时修改“禁用 Excel VBA 中的剪贴板提示”中的代码,但我没有运气。

这是我的原始代码:

Sub CFM56copydata()
Dim wbk As Workbook
'The workbook is opened using the text from a textbox in a userform i.e:
strFirstFile = Userform1.dog.Text
Set wbk = Workbooks.Open(strFirstFile)
With wbk.Sheets("Sheet1")
Range("A1").Select
Range(Selection, Selection.End(xlDown)).Select
Range(Selection, Selection.End(xlToRight)).Select
Selection.Copy
End With
Set wbk2 = ThisWorkbook
wbk2.Sheets("dog").Range("A1").Insert
wbk.Close
End Sub
Run Code Online (Sandbox Code Playgroud)

以下是我尝试调整它的方法,这样我就完全避免使用剪贴板。(不起作用,在第 12 行给了我一个调试错误)

Sub fix()
Dim wbk As Workbook
strFirstFile = Userform1.CFM56path.Text
Set wbk = Workbooks.Open(strFirstFile)
Set wbk2 = ThisWorkbook
Dim rSrc As Range
Dim rDst As Range
Range("A1").Select
Range(Selection, Selection.End(xlDown)).Select
Range(Selection, Selection.End(xlToRight)).Select
Set rSrc = Selection
Set rDst = wbk2.Sheets("dog").Cells("A1").Resize(rSrc.Rows.Count, rSrc.Columns.Count)
rDst = rSrc
wbk.Close
End Sub
Run Code Online (Sandbox Code Playgroud)

Net*_*loh 5

如果您将wbk.Close语句更改为:

Application.DisplayAlerts = False
wbk.Close
Application.DisplayAlerts = True
Run Code Online (Sandbox Code Playgroud)


ron*_*ron 5

如果剪贴板提示是问题所在,只需在粘贴完成后将其清空即可。

wbk2.Sheets("dog").Range("A1").Insert
Application.CutCopyMode = False
wbk.Close
Run Code Online (Sandbox Code Playgroud)

  • 需要明确的是,这不会清空剪贴板。它仅删除复制区域周围的“跳舞的蚂蚁”。如果您复制足够的数据,您仍然可能会收到该消息。 (2认同)