0

私はVBAを初めて使用するので、おそらく本当に基本的なことを求めています-ごめんなさい!「7月のアーカイブ」と呼ばれる別のワークシートに移動したい一連のレコードを含むワークシートがあります。私はこのコードを使用していますが、これにより「7月のアーカイブ」の宛先セルが上書きされることがわかっています。しかし、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
4

1 に答える 1

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
于 2012-07-11T16:05:48.247 に答える