需要更快地计算数据

时间:2017-04-12 18:39:00

标签: excel excel-vba worksheet-function worksheet vba

我正在努力使用此代码请帮助我。我想记录这段代码中的更改,但它逐个单元格,这使得它变慢。我的活动工作表运行200毫秒,这个代码更改其作业值时非常快。是否有任何方法可以同时显示值而不是通过转到每个单元格。我心中有这么多的困惑,如果我的要求没有任何意义,请原谅我。

Private Sub Worksheet_Change(ByVal Target As Range)

Const Scope = "G9:H9,G11:H11,G13:H13,G15:H15,G17:H17,G19:H19,G21:H21,G23:H23,G25:H25,G27:H27,G29:H29,G31:H31,G33:H33,G35:H35,G37:H37,G39:H39,G41:H41,G43:H43,G45:H45,G47:H47,G49:H49,G51:H151,G53:H53,G55:H55,G57:H57,G59:H59,G61:H61,G63:H63,G65:H65,G67:H67" ' monitoring area

Static oData As New Dictionary
Dim rCells As Range
Dim oCell
Dim dDelta

Set rCells = Application.Intersect(Target, Target.Parent.Range(Scope))
If Not rCells Is Nothing Then
    For Each oCell In rCells
        With oCell
            dDelta = oData(.Address)
           .Offset(0, 1).Value = dDelta
            oData(.Address) = .Value
        End With
    Next
End If

End Sub

1 个答案:

答案 0 :(得分:1)

您是否尝试关闭屏幕更新?在Sub line下面添加此行,看看这对速度是否有帮助。

Application.ScreenUpdating = False