ªð¦^¦Cªí ¤W¤@¥DÃD µo©«

[µo°Ý] ¸ê®Æ¾ã²z

[µo°Ý] ¸ê®Æ¾ã²z

¦U¦ì¤j¤j¦n¡A

¤p©f§Ú¾ã²z¸ê®Æ®É¥X²{¤F¤@­ÓÃøÃD¡A·Q½Ð¦U¦ìÀ°¦£³B²z
½s¸¹¸ò­ì®Æ¥i¯à¬Û¦P¦ý§å¸¹¤]³\¤£¦P(¸ê®Æsheet)¡A¦p¦ó§e²{¥X¥DºÞ·Q¬Ýªºªí³æ(§e²{ªísheets)
¥Ø«e¤½¦¡¥u¯à§ì¥X²Ä¤@µ§¡AµLªk§ì¨ì²Ä¤Gµ§§å¸¹¡A¦³¿ìªk¥i¥H¸Ñ¨M¶Ü¡H
¹ê»Ú¤W½s¸¹¬O100-300µ§
­ì®Æ¬OA-Z¡A¦ý¤£½T©w¦P½s¸¹+­ì®Æªº®Æ¸¹¦³´Xµ§
Á|¨Ò½s¸¹100­ì®ÆCªº®Æ¸¹¥Ø«e2µ§¡A¦ý¹ê»Ú¦³¥i¯à4-5µ§

test2.zip (7.88 KB)

¦^´_ 1# ÅÚ½³ªd

½Ð´ú¸Õ¬Ý¬Ý¡AÁÂÁÂ
Sub test()
Dim Arr, Brr, xD, xD1, TT, n%, C%, m%, i&, k%
Set xD = CreateObject("Scripting.Dictionary")
Set xD1 = CreateObject("Scripting.Dictionary")
Arr = Range([¸ê®Æ!c1], [¸ê®Æ!a65536].End(3))
For i = 2 To UBound(Arr)
    If Arr(i, 2) = "" Then GoTo 99
    If Not xD.Exists(Arr(i, 2) & "") Then
        k = k + 1: xD(Arr(i, 2) & "") = k
    End If
99: Next
ReDim Brr(1 To UBound(Arr), 1 To xD.Count + 1)
With Sheets("§e²{ªí")
    .Range("b1").Resize(, xD.Count) = xD.keys
    For i = 2 To UBound(Arr)
        C = xD(Arr(i, 2) & "") + 1
        If xD1.Exists(Arr(i, 1)) Then
            m = xD1(Arr(i, 1))
            If IsEmpty(Brr(m, C)) Then Brr(m, C) = Arr(i, 3) Else Brr(m, C) = Brr(m, C) & "," & Arr(i, 3)
        Else
            n = n + 1: xD1(Arr(i, 1)) = n
            Brr(n, 1) = Arr(i, 1): Brr(n, C) = Arr(i, 3)
        End If
    Next
    .Range("a2").Resize(n, xD.Count) = Brr
End With
End Sub
11.PNG

TOP

ÀH·NºÛ "EXCEL°g"  blog  ©Îhttps://blog.xuite.net/hcm19522/twblog
¤w¦¬¶°8500½g EXCEL¨ç¼Æ

TOP

¦^´_ 2# samwang


    ÁÂÁ¡A´ú¸Õok

TOP

¦^´_ 3# hcm19522


    ÁÂÁ¡A½Ð°Ý¦pªG¦b¤£ª¾¹D¦P¤@­ì®Æ¦³´Xµ§ªºª¬ºA¤U¬O¤£¬O³o¨ç¼Æ´NµLªk¨Ï¥Î¡H

TOP

¦^´_ 4# ÅÚ½³ªd


¤£¦n·N«ä¡A2#¦³­Ó¤p°ÝÃD¡A¥ÑxD.Count§ï¬°Ubound(Brr,2)¡A¦p¤U¬õ¦r³¡¤À¡AÁÂÁÂ

.Range("a8").Resize(n, UBound(Brr, 2)) = Brr

TOP

ÀH·NºÛ "EXCEL°g"  blog  ©Îhttps://blog.xuite.net/hcm19522/twblog
¤w¦¬¶°8500½g EXCEL¨ç¼Æ

TOP

¥»©«³Ì«á¥Ñ samwang ©ó 2021-11-4 12:03 ½s¿è

¦^´_ 1# ÅÚ½³ªd

½Ð´ú¸Õ¬Ý¬Ý¡AÁÂÁ¡C

Sub ³æµ§¸ê®Æ()
Dim Arr, Brr, Crr(1 To 1, 1 To 100), xD, xD1, m%, m0%, m1%
Dim k0%, k1%, k%, ky, CMax, T$, n%, C%, C1%, i&
Set xD = CreateObject("Scripting.Dictionary")
Set xD1 = CreateObject("Scripting.Dictionary")
With Sheets("¸ê®Æ")
        With .Range(.[C1], .[a65536].End(xlUp))
            Brr = .Value
            .Sort Key1:=.Item(1), Order1:=xlAscending, _
                Key2:=.Item(2), Order2:=xlAscending, Header:=xlYes
            Arr = .Value
            .Value = Brr
        End With
End With
For i = 2 To UBound(Arr)
    If Arr(i, 2) = "" Then GoTo 97
    T = Arr(i, 1) & "_" & Arr(i, 2)
    If Not xD.Exists(T) Then '¨úÄæ¼Æ
        xD(Arr(i, 2) & "") = 1: xD(T) = ""
    Else
        k0 = xD(Arr(i, 2) & ""): k1 = xD1(Arr(i, 2) & "")
        If k0 > k1 Then k = k0 + 1 Else k = k1 + 1
        xD1(Arr(i, 2) & "") = k
    End If
97: Next
For Each ky In xD.keys    '¦C¥X²Ä¤@¦CªíÀY
    If InStr(ky, "_") Then GoTo 98
    If xD1.Exists(ky) Then
        For j = 1 To xD1(ky): y = y + 1: Crr(1, y) = ky: Next
    Else
        y = y + 1: Crr(1, y) = ky: s = s + 1
    End If
98: Next
xD1.RemoveAll
ReDim Brr(1 To UBound(Arr), 1 To y + 1)
With Sheets("§e²{ªí")
    .[a1:aa100] = ""
    .Range("b1").Resize(, y) = Crr
    For i = 2 To UBound(Arr)
        If Arr(i, 2) = "" Then GoTo 99
        C = Application.WorksheetFunction.Match(Arr(i, 2), Sheets(2).Range("a1").Resize(, y + 1), 0)
        If xD1.Exists(Arr(i, 1)) Then
            m = xD1(Arr(i, 1))
            If IsEmpty(Brr(m, C)) Then
                Brr(m, C) = Arr(i, 3)
            Else
                If m0 = 0 Then m0 = m
                If m0 <> m Then C1 = 0
                If C1 > C Then C1 = C1 + 1 Else C1 = C + 1
                Brr(m, C1) = Arr(i, 3)
            End If
        Else
            n = n + 1: xD1(Arr(i, 1)) = n
            Brr(n, 1) = Arr(i, 1): Brr(n, C) = Arr(i, 3)
        End If
99: Next
    .Range("a2").Resize(n, y + 1) = Brr
End With
End Sub
22.PNG

TOP

VBAªþÀÉ:
Xl0000805.rar (12.08 KB)

®ÄªG:
xx001.gif
2021-11-6 19:01

TOP

        ÀR«ä¦Û¦b : ¥Ç¿ù¥XÄb®¬¤ß¡A¤~¯à²M²bµL·Ð´o¡C
ªð¦^¦Cªí ¤W¤@¥DÃD