突出显示重叠日Excel VBA

时间:2013-01-25 05:47:32

标签: excel-vba vba excel

我有以下问题需要解决,以提高代码执行任务的速度。

我有一张桌子上有租车名称和两个日期 - 从和到。我需要检查范围(比如10k行)检查并突出显示所有重叠日期。

不租车到

1 ABC 01 Jan 12 12月12日 2 ABC 14 Jan 12 15 1月12日 3 ABC 25 Jan 12 02 Feb 12
4 DEF 01 Jan 12 12月12日 5 DEF 12 Jan 12 02 2月12日 6 DEF 14 Jan 12 15 1月12日

对于租车DEF,有重叠的日子,实际上是重复计算,我需要能够突出显示,以便用户可以快速识别和纠正。

这是我开发的代码。问题是,如果你有一个10k行的范围,它是非常慢的。

我正在使用Windows 7 Ultimate和Office / Excel 2010

    Function CheckOverlap(StartLine, EndLine, StartColumn)

Dim i As Integer, y As Integer
Dim DateToCompare
Dim HireCar
Dim Count As Integer
Dim Msg, Style, Title, Response

'Check StartDate Column
For i = StartLine To EndLine

    DateToCompare = Cells(i, StartColumn)
    HireCar = Cells(i, 2)
    For y = StartLine To EndLine
        'If we are at the same line with DateToCompare cell then we should not perform any check
        If i <> y Then    
            If DateToCompare >= Cells(y, StartColumn) And DateToCompare <= Cells(y, StartColumn + 1) And HireCar = Cells(y, 2) Then
                'We should highlight both cells that contain overlapping dates
                ActiveSheet.Cells(i, StartColumn).Interior.Color = 5296274
                ActiveSheet.Cells(y, StartColumn).Interior.Color = 5296274
            End If
        End If
    Next y
Next i

HireCar = 0

'Check EndDate Column
For i = StartLine To EndLine

    DateToCompare = Cells(i, StartColumn + 1)
    HireCar = Cells(i, StartColumn - 1)
    For y = StartLine To EndLine
        'If we are at the same line with DateToCompare cell then we should not perform any check
        If i <> y Then    
            If DateToCompare >= Cells(y, StartColumn) And DateToCompare <= Cells(y, StartColumn + 1) And HireCar = Cells(y, StartColumn - 1) Then
                'We should highlight both cells that contain overlapping dates
                ActiveSheet.Cells(i, StartColumn + 1).Interior.Color = 5296274
                ActiveSheet.Cells(y, StartColumn + 1).Interior.Color = 5296274
            End If
        End If
    Next y
Next i


'Last check: If the starting and ending date are the same
For i = StartLine To EndLine
    If Cells(i, StartColumn) - Cells(i, StartColumn + 1) = 0 Then
        ActiveSheet.Cells(i, StartColumn).Interior.Color = 5296274
        ActiveSheet.Cells(i, StartColumn + 1).Interior.Color = 5296274
    End If
Next i

' If there are no Overlap Days in Database skip filtering
' StartDate and EndDate Column
' Count Cells with Interior.Color = 5296274 (Green Colour)
Count = 0

For i = StartLine To EndLine
    If Cells(i, StartColumn).Interior.Color = 5296274 Then
        Count = Count + 1
    End If
Next i

' Msg if Database has no Overlap Days
Msg = "Validation check completed. There are 'NO' Overlap Days"
Style = vbOKOnly
Title = "Cash Flow"

' Require on Error Resume Next in case Database is NOT filtered
On Error Resume Next
If Count = 0 Then
    ActiveSheet.ShowAllData
    Response = MsgBox(Msg, Style, Title)
    Exit Function
Else
    Call Filter_Colour
End If

MsgBox "Any Green highlights indicate Overlap Days"

结束功能

2 个答案:

答案 0 :(得分:0)

最快的方法是对表格进行排序(第一顺序:汽车,第二顺序:从最近开始)

然后为每一行: 碰撞如果上面的线是同一辆车,并且从上面开始的日期大于当前线的起始日期。

您可以使用VBA或Excel-Formulas执行这些步骤。

答案 1 :(得分:0)

这是一个简单的算法,当后面的行有重叠时显示空白。要运行此操作,严格假定您的CAR列按问题中显示的样本进行排序。

Option Explicit

'-- assuming the CAR names column is sorted
'-- so each car block in one place
'-- run on button click event

Sub FindOverlaps()
Dim i As Integer, j As Integer
Dim vInput As Variant
Dim rng As Range

Set rng = Sheets(2).Range("B2:E7")
vInput = WorksheetFunction.Transpose(WorksheetFunction.Transpose(rng))

For i = LBound(vInput) To UBound(vInput) - 1
    For j = LBound(vInput) + 1 To UBound(vInput)
        If vInput(i, 2) = vInput(j, 2) Then
            If vInput(i, 4) = vInput(j, 3) Then
                vInput(j, 3) = ""
                vInput(j, 4) = ""
            End If
        End If
    Next j
Next i

rng.Offset(0, 6).Resize(UBound(vInput), UBound(Application.Transpose(vInput))) = vInput

End Sub

输出:

enter image description here


根据OP的评论编辑

  1. 根据输入数据将已排序的数据转置为相同范围,因此请删除offset(0,4)
  2. 添加conditiona formatting以突出显示指定范围内的null。 (否则整张纸将在空单元格的地方着色)
  3. 代码更改:

    rng.Offset(0, 6).FormatConditions.Delete
    rng.Offset(0, 6).FormatConditions.Add Type:=xlCellValue, Operator:=xlEqual, _
            Formula1:="="""""
    rng.Offset(0, 6).FormatConditions(1).Interior.ColorIndex = 20