1

这看起来非常简单和直接,但无论我进行多少测试和搜索,我都无法解决。我目前有脚本可以在不选择任何内容的情况下打开 AutoFilter,但我认为我可以在不选择数据的情况下复制数据并粘贴到新的工作表中。但是,在它完成操作后,它确实将 A:K 列显示为选中状态。我一直无法弄清楚如何取消选择工作表上的那些列,也无法找出如何在不首先选择它们的情况下复制和粘贴。任何指导表示赞赏。谢谢。

Sub RunScript()

Application.ScreenUpdating = False
Application.DisplayAlerts = False

Dim ws1 As Worksheet
Set ws1 = ThisWorkbook.Sheets("Data")

Sheets.Add.Name = "copy"
Dim galreqws As Worksheet
Set galreqws = ThisWorkbook.Sheets("copy")

Sheets("Data").Select
Range("A:K").AutoFilter

ws1.Range("A1:K1000").Copy Destination:=Sheets("copy").Range("A1:K1000")

galreqws.Delete

'Sheets("Data").Select
Range("A:K").AutoFilter
Range("A:K").Select
Sheets("Buttons").Select

Application.ScreenUpdating = True
Application.DisplayAlerts = True

End Sub
4

2 回答 2

1

.Select除非您真的想让用户看到选定的范围,否则使用它通常是不好的做法。据我所知,不需要采取任何行动.Select

以下是您可以采取的一些措施来改进您的代码的建议:

Sub RunScript()

    Application.ScreenUpdating = False
    Application.DisplayAlerts = False

    Dim wsCurrent As Worksheet
    Set wsCurrent = ActiveSheet

    Dim wsData As Worksheet
    Set wsData = ThisWorkbook.Worksheets("Data")

    Dim wsGalreq As Worksheet
    ' Note that .Add will activate the new sheet so we'll
    ' need to reactivate the worksheet that was previously active
    'Set wsGalreq = Worksheets.Add
    'wsGalreq.Name = "copy"
    Set wsGalreq = Worksheets("copy")

    wsData.Range("A:K").AutoFilter 1, "Supplier A"
    ' Find the used range in columns A to K and copy over starting
    ' at cell A1 of wsGalreq
    Intersect(wsData.UsedRange, wsData.Range("A:K")).Copy Destination:=wsGalreq.Range("A1")

    ' Doubt deleting the new sheet was intentional?
    ' wsGalreq.Delete

    ' Now change the view to the desired worksheet, uncomment one:
    'Worksheets("Buttons").Select
    'wsCurrent.Activate

    Application.ScreenUpdating = True
    Application.DisplayAlerts = True

End Sub
于 2016-02-28T11:26:23.273 回答
0

从您的代码中删除下面的行。

Range("A:K").Select
于 2016-02-27T05:08:10.487 回答