2012-07-11 63 views
0

我是VBA新手,所以我可能会问一些基本的东西 - 对不起! 我有一张工作表,其中包含一系列记录,我想将它们放入名为“July Archive”的不同工作表中。我使用这段代码,我知道这将覆盖“July Archive”中的目标单元格。但是我收到一个错误,提示pasteValue操作失败。将数据粘贴到新工作表中

另外,如何追加单元而不是覆盖。我尝试了PasteAppend,但得到一个错误说它不支持该对象。

Sub Selectweeklyreport() 

    ActiveSheet.Range("a16", ActiveSheet.Range("f16").End(xlDown)).Cut 
    ActiveSheet.Goto ("July Archive") 
    Selection.PasteSpecial Paste:=xlValues, Operation:=xlNone, SkipBlanks:= _ 
    False, Transpose:=False 

End Sub 

回答

1

是这样的?

Sub Selectweeklyreport() 
    Dim wsI As Worksheet, wsO As Worksheet 
    Dim lRow As Long 

    '~~> Replace this with the relevant sheet name 
    Set wsI = Sheets("Sheet1") 
    Set wsO = Sheets("July Archive") 

    With wsI 
     '~~> Get the last Row in Sheet1 
     lRow = .Range("F" & .Rows.Count).End(xlUp).Row 

     '~~> Copy the range from Sheet1 
     .Range("A16:F" & lRow).Copy 'and not .Cut???? 

     '~~> Get the next available row in July Archive 
     lRow = wsO.Range("A" & wsO.Rows.Count).End(xlUp).Row + 1 

     '~~> Paste Special Values 
     wsO.Range("A" & lRow).PasteSpecial Paste:=xlValues, _ 
     Operation:=xlNone, SkipBlanks:=False, Transpose:=False 
    End With 
End Sub 
相关问题