- ©«¤l
- 1447
- ¥DÃD
- 40
- ºëµØ
- 0
- ¿n¤À
- 1471
- ÂI¦W
- 0
- §@·~¨t²Î
- Windows 7
- ³nÅ骩¥»
- Excel 2010 & 2016
- ¾\ŪÅv
- 50
- ©Ê§O
- ¨k
- ¨Ó¦Û
- ¥xÆW
- µù¥U®É¶¡
- 2020-7-15
- ³Ì«áµn¿ý
- 2025-2-11
|
¥»©«³Ì«á¥Ñ Andy2483 ©ó 2023-7-10 11:16 ½s¿è
¦^´_ 32# ã´£³¡ªL
¦^´_ 30# qaqa3296
¦^´_ 27# cowww
ÁÂÁ«e½ú¦A´£¨Ñ·s½d¨Ò
ÁÂÁ 㴣³¡ªL«e½ú«ü¾É
ÁÂÁ qaqa3296 ¤@°_¾Ç²ß,¶W»{¯uªº¾Ç²ß¤è®×
«á¾Ç¤]´£¨Ñ¾Ç²ß¤è®×«Øij¦p¤U,½Ð«e½ú°Ñ¦Ò
°õ¦æµ²ªG:
Option Explicit
Sub ¾÷¥x±Æµ{_Click()
Application.ScreenUpdating = False
Dim Brr, Z, A$, B$, C%, Nm&, chk, Np, i&, R&, T$, T1$, PH$, FN$, xB As Workbook, Sh As Worksheet
Set Z = CreateObject("Scripting.Dictionary")
PH = ThisWorkbook.Path: FN = "²§°Êªí±Æ§Ç.xlsm"
On Error Resume Next: Set xB = Workbooks(FN): On Error GoTo 0
If xB Is Nothing Then Set xB = Workbooks.Open(PH & "\" & FN): chk = 1
With xB.Sheets("²§°Êªí±Æ§Ç")
Brr = Range(.[G1], .[A65536].End(3)(2))
End With
If chk = 1 Then xB.Close 0
For i = 2 To UBound(Brr) - 1
If IsError(Brr(i, 1)) Or IsError(Brr(i, 2)) Or Brr(i, 4) = "" Then GoTo i00
'¡ô1.2Ä榳¿ù»~È ©ÎµL¼Ò¨ã¸¹½X ²¤¹L
T = Brr(i, 4): T1 = Brr(i, 1): A = Z(T1)
If A = "" Then
For R = i To UBound(Brr)
If IsError(Brr(R, 1)) Or IsError(Brr(R, 2)) Or Brr(R, 4) = "" Then GoTo R00
'¡ô1.2Ä榳¿ù»~È ©ÎµL¼Ò¨ã¸¹½X ²¤¹L
If T1 <> Brr(R, 1) Then Exit For
For C = 4 To 7: B = B & " " & Brr(R, C): Next:
B = Brr(R, 3) & " " & B
If i = R Then A = Brr(R, 1) & vbLf & B Else A = A & vbLf & B
Z(T1) = A: B = ""
R00: Next
End If
If Z(T) = "" Then
Z(T) = Z(T1)
ElseIf InStr(Z(T), Z(T1)) = 0 Then
Z(T) = Z(T) & vbLf & vbLf & Z(T1)
End If
i00: Next
Brr = Range([±M®×!Z1], [±M®×!D65536].End(3))
[Z:Z].ClearComments: [Z:Z].Interior.ColorIndex = xlNone
For i = 1 To UBound(Brr)
T1 = Brr(i, 1)
If Z(T1) = "" And Z(Brr(i, 23)) <> "" Then
Cells(i, 26).Interior.ColorIndex = 38
Np = Np + 1: GoTo i01
End If
If T1 = "" Or Z(T1) = "" Then GoTo i01
If Cells(i, 26) = "" Then
Nm = Nm + 1
Cells(i, 26).Interior.ColorIndex = 6
End If
With Cells(i, 26).AddComment
.Text Text:=Replace(Z(T1), " " & T1, "_¡¹_" & T1)
.Shape.TextFrame.Characters.Font.Size = 16
.Shape.DrawingObject.AutoSize = True
End With
i01: Next
If Nm + Np > 0 Then
MsgBox "¦³±Æµ{ µL¼Ð¥Ü¾÷¥x: " & Nm & " Ó" & vbLf & vbLf & _
"¦³¼Ð¥Ü¾÷¥x µL±Æµ{: " & Np & " Ó"
End If
Set Z = Nothing: Erase Brr: Set xB = Nothing: Set Sh = Nothing
End Sub |
|