|
Public arr
Private Sub Worksheet_Change(ByVal Target As Range)
brr = Sheet2.UsedRange
Set d1 = CreateObject("scripting.dictionary")
Set d = CreateObject("scripting.dictionary")
If Target.Column = 3 And Target.Row > 4 And Target.Count = 1 And Target <> "" Then
Target.Offset(, 1) = ""
Target.Offset(, 2) = ""
For j = 1 To UBound(arr)
If arr(j, 1) = Target Then d(arr(j, 2)) = ""
Next j
s = ""
For Each c In d.keys
s = s & "," & c
Next c
d.RemoveAll
With Target.Offset(, 1).Validation
.Delete
.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:=Right(s, Len(s) - 1)
End With
For i = 2 To UBound(brr)
If brr(i, 2) = Target Then
d1(brr(i, 3)) = ""
d2(brr(i, 2) & "||" & brr(i, 3)) = brr(i, 4)
End If
Next
k = d1.keys
For i = 0 To d1.Count - 1
f = f & k(i) & ","
Next
With Target.Offset(, 5).Validation
.Delete
.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:=f
End With
Target.Offset(, 1).Select
End If
If Target.Column = 4 And Target.Row > 4 And Target.Count = 1 And Target <> "" Then
Target.Offset(, 1) = ""
For j = 1 To UBound(arr)
If arr(j, 1) & "," & arr(j, 2) = Target.Offset(, -1) & "," & Target Then d(arr(j, 3)) = ""
Next j
s = ""
For Each c In d.keys
s = s & "," & c
Next c
d.RemoveAll
With Target.Offset(, 1).Validation
.Delete
.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:=Right(s, Len(s) - 1)
End With
Target.Offset(, 1).Select
End If
If Target.Column = 5 And Target.Row > 4 And Target.Count = 1 And Target <> "" Then
With Sheet1
.Cells(Target.Row, 6).Select
.Cells(Target.Row, 6) = Application.WorksheetFunction.VLookup(.Cells(Target.Row, 3) & .Cells(Target.Row, 4) & .Cells(Target.Row, 5), Sheet3.Range("A:F"), 5, 0)
.Cells(Target.Row, 7) = Application.WorksheetFunction.VLookup(.Cells(Target.Row, 3) & .Cells(Target.Row, 4) & .Cells(Target.Row, 5), Sheet3.Range("A:F"), 6, 0)
End With
End If
If Target.Column = 8 And Target.Row > 4 And Target.Count = 1 And Target <> "" Then
For i = 2 To UBound(brr)
If brr(i, 2) = Target.Offset(0, -5) And brr(i, 3) = Target Then jg = brr(i, 4)
Next
Target.Offset(0, 1) = jg
End If
End Sub
Public Sub worksheet_selectionchange(ByVal Target As Range)
Dim j&, s$, d As Object, c
Set d = CreateObject("scripting.dictionary")
With Sheets("裁剪数")
arr = .Range("b2:f" & .[a1048576].End(xlUp).Row)
End With
If Target.Column <> 3 Or Target.Row < 5 Or Target.Count <> 1 Then Exit Sub
For j = 1 To UBound(arr)
d(arr(j, 1)) = ""
Next j
For Each c In d.keys
s = s & "," & c
Next c
With Target.Validation
.Delete
.Add Type:=xlValidateList, AlertStyle:=xlValidAlertStop, Operator:=xlBetween, Formula1:=Right(s, Len(s) - 1)
End With
End Sub |
|