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

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

¥»©«³Ì«á¥Ñ Andy2483 ©ó 2022-10-27 14:44 ½s¿è

¦^´_ 9# ­ã´£³¡ªL
'ÁÂÁ«e½ú
'³o©«²ß±o¦h¼Ëª¾ÃÑ
'1.Range([¸ê®Æ!c1], [¸ê®Æ!a1].Cells(Rows.Count, 1).End(xlUp))
'  ¬Ý¦ü²³æªºÀx¦s®æ½d³ò!¾Ç¨ì¤F [¸ê®Æ!c1] ·|ÅýRange()«ü¦V ¸ê®Æªí
'  ¥H«e»~¥H¬° ¨S¦³¤u§@ªí«ü¦VªºRange() ¤@©w¬O¦bActiveSheet
'  §_«h¤@©w­n«ü¦V­þ­Óªí Sheets("¸ê®Æ").Range()
'2.«e½ú«Ü¦³¤ß³£·|¥Î¤£¦Pªº»yªk±Òµo«á¾Ç­Ì!¤£¬O¾÷±ñ¦¡ªº¦^µª!ÁÂÁÂ!
'3.Format(T(3), "0000") ¾Ç²ß¨ì¦p¦ó¼Æ¦r¸É¨¬«e¤èªº0 ¦¨¬°·Q­nªº¼Æ¦r½X¼Æ
'4.¥Î¦r¨å»P°}¦C ¾Q³¯¼ÐÃD¦C»P¼ÐÃDÄæ ¦n¹³¤w¸g¬ÝÀ´! ¦ý¤S¤£·|¥Î!¦A¶Ô½m¬Ý¬Ý!
'5.¾Ç¨ì Äæ±Æ§Ç
'6.¾Ç¨ì ¥h°£ "|"²Å¸¹(§t)¥kÃ䪺¦r¤¸  Replace "|*", "", Lookat:=xlPart
'7.¾Ç¨ì ¯d¤U[A1]Àx¦s®æ!¨ä¾lÀx¦s®æ§R°£
'8.±×½uÀHÀx¦s®æÁY©ñ

¤@¶}©l¶K¤J:


Äæ±Æ§Ç:


¦C±Æ§Ç:


¼ÐÃD¦C¯d­ì®Æ»PÅã¥Ü®æ½u:


±×½uÀHÀx¦s®æÁY©ñ:


¥H¤U¤ß±oµù¸Ñ½Ð«e½ú¦A«ü±Ð!ÁÂÁ«e½ú
Sub TEST_A1()
Dim Arr, Brr, xD, T$(3), i&, j%, R&, C%, X&, Y%
'¡ô«Å§iÅܼÆ,§å¦¸«Å§iT¬O¦r¦êÅÜ¼Æ T(0)~T(3)
Call ²M°£
'¡ô°õ¦æ°Æµ{¦¡ ²M°£()

Set xD = CreateObject("Scripting.Dictionary")
'¡ô¥O xD¬O¦r¨å
Arr = Range([¸ê®Æ!c1], [¸ê®Æ!a1].Cells(Rows.Count, 1).End(xlUp))
'¡ô¥O Arr¬O°}¦C,­Ë¤J ¸ê®Æªí¸ÌC1¨ìAÄæ³Ì«á¤@­Ó¦³¤º®eÀx¦s®æ
'³o¨â­ÓÀx¦s®æ¶¡ÂX®i¨ì³Ì¤p¤è¥¿°Ï°ìÀx¦s®æªº­È
ReDim Brr(1 To UBound(Arr), 1 To 200)
'¡ô«Å§i Brr°}¦Cªº½d³ò! Áa¦V¬O1 ¨ì Arr°}¦Cªº¦C¼Æ
'¾î¦V¬O1 ¨ì 200 Äæ¼Æ

For i = 2 To UBound(Arr)
'¡ô³]¥~¶¶°j°é ±q2 ¨ì Arr°}¦C³Ì«á¦C¼Æ
    For j = 1 To 3
    '¡ô³]¤º¶¶°j°é ±q1 ¨ì3
        T(j) = Arr(i, j)
        '¡ô¥O°j°é¤¤ T¦r¦êÅܼƸˤJArr°}¦C¹ïÀ³­È
        If T(j) = "" Then
        '¡ô¦pªG ¦¹¤º°j°é¤¤ T¦r¦êÅÜ¼Æ ¸Ë¤J¤FªÅ®æ
           GoTo 101
           '¡ô±ø¥ó¦¨¥ß!´N¸õ¨ì 101 Ä~Äò°õ¦æ
        End If
    Next j
    T(0) = T(2) & "|" & Format(T(3), "0000")
    '¡ô¥O²Ä1­ÓT¦r¦êÅܼƬO ²Ä3­ÓT¦r¦êÅÜ¼Æ & "|" & ²Ä4­ÓT¦r¦ê(4½X¼Æ¦r)
    X = xD(T(1))
    '¡ô¥OX¼Æ¦rÅܼƬO xD¦r¨å¸Ì¥H ²Ä2­ÓT¦r¦ê ­È¬°keyªºitem
    '¤@¶}©l¬O¬d¤£¨ì item!¦ý¬O¦r¨å¸Ì¤w¸g¦¬¯Ç¤F ²Ä2­ÓT¦r¦ê ­È¬°key
    '¦]¬°X¼Æ¦rÅܼÆ!¬d¤£¨ì´N¬Oªì©l­È0

    Y = xD(T(0))
    '¡ô¥OY¼Æ¦rÅܼƬO xD¦r¨å¸Ì¥H ²Ä1­ÓT¦r¦ê ­È¬°keyªºitem
    '¤@¶}©l¤]¬O¬d¤£¨ì item!¦ý¬O¦r¨å¸Ì¤w¸g¦¬¯Ç¤F ²Ä1­ÓT¦r¦ê ­È¬°key
    '¦]¬°Y¼Æ¦rÅܼÆ!¬d¤£¨ì´N¬Oªì©l­È0

    If X = 0 Then
    '¡ô¦pªGX¼Æ¦rÅܼƬOªì©l­È0
       R = R + 1
       '¡ô±ø¥ó¦¨¥ß!R¼Æ¦rÅܼƴN²Ö¥[ 1
       X = R + 1
       '¡ô±ø¥ó¦¨¥ß!X¼Æ¦rÅܼƤS¥HR¼Æ¦rÅܼƦA +1
       '¦]¬°¼ÐÃDÄæ¬O±q©¹¤U²Ä2­Ó¶}©l
       xD(T(1)) = X
       '¡ô¥O xD¦r¨å¤¤ ²Ä2­ÓT¦r¦êÅܼÆ(½s¸¹) ¬°keyªºitem = X¼Æ¦rÅܼÆ
       '©Ò¥H¶}©l¸Ë¤Jªºitem¬O ¼Æ¦r2

       Brr(X, 1) = T(1)
       '¡ô¤@¶}©l¬O¥OBrr°}¦C²Ä2¦C²Ä1Äæ¬O ²Ä2­ÓT¦r¦êÅܼÆ(½s¸¹)
       '¡ô³o¬O¼ÐÃDÄæ

    End If
    If Y = 0 Then
    '¡ô¦pªGY¼Æ¦rÅܼƬOªì©l­È0
       C = C + 1
       '¡ô±ø¥ó¦¨¥ß!C¼Æ¦rÅܼƴN²Ö¥[ 1
       Y = C + 1
       '¡ô±ø¥ó¦¨¥ß!Y¼Æ¦rÅܼƤS¥HC¼Æ¦rÅܼƦA +1
       '¦]¬°¼ÐÃD¦C¬O±q©¹¥k²Ä2­Ó¶}©l

       xD(T(0)) = Y
       '¡ô¥O xD¦r¨å¤¤ (­ì®Æ)& "|" &(§å¸¹) ¬°keyªºitem = Y¼Æ¦rÅܼÆ
       Brr(1, Y) = T(0)
       '¡ô¤@¶}©l¬O¥OBrr°}¦C²Ä1¦C²Ä2Äæ¬O ²Ä1­ÓT¦r¦êÅÜ¼Æ (­ì®Æ)& "|" &(§å¸¹)
       '¡ô³o¬O¼ÐÃD¦C

    End If
    Brr(X, Y) = T(3)
    '¡ô¼ÐÃD¦CÄæ©Ò¹ïÀ³ªº §å¸¹©ñ¤J Brr°}¦C¤¤
101: Next i
Brr(1, 1) = "¡@¡@¡@­ì®Æ¡@½s¸¹"
'¡ô¥OBrr°}¦C²Ä1¦C²Ä1ÄæÀx¦s®æªº¦r¦ê
With [§e²{ªí!A1].Resize(R + 1, C + 1)
'¡ôR¬O¤£¥]§t¼ÐÃD¦C!©Ò¥H­n +1 ,C¬O¤£¥]§t¼ÐÃDÄæ!©Ò¥H­n +1
    .Value = Brr
    '¡ô±NBrr°}¦C±q §e²{ªí[A1]¶K¤J­È
    .Columns(2).Resize(, C).Sort Key1:=.Cells(1, 2), Order1:=xlAscending, Header:=xlNo, Orientation:=xlLeftToRight
    '¡ôÄæ¥H¼ÐÃD¦C±Æ§Ç
    .Rows(2).Resize(R).Sort Key1:=.Cells(2, 1), Order1:=xlAscending, Header:=xlNo, Orientation:=xlTopToBottom
    '¡ô¦C¥H¼ÐÃDÄæ±Æ§Ç
    .Rows(1).Replace "|*", "", Lookat:=xlPart
    '¡ô§â¼ÐÃD¦C¥h°£ "|"²Å¸¹(§t)¥kÃ䪺¦r¤¸!¼ÐÃD¦C³Ñ¤U (­ì®Æ)
    .Borders.LineStyle = 1
    '¡ôÅýÀx¦s®æ®æ½uÅã¥Ü ²Ó¹ê½u
End With
End Sub

Sub ²M°£()
With Sheets("§e²{ªí").UsedRange
    .Offset(1, 0).EntireRow.Delete
    .Offset(, 1).EntireColumn.Delete
    '¯d¤U[A1]Àx¦s®æ!¨ä¾lÀx¦s®æ§R°£
End With
End Sub

TOP

¦^´_ 9# ­ã´£³¡ªL
«e½ú¤È¦w
¥H¤U¬O¥Î¤T­Ó¦r¨å¤è¦¡³B¸Ì,½Ð«e½ú¦A«ü¾É!
ÁÂÁ«e½ú

Option Explicit
Sub TEST_20221028()
Dim Arr, i&, j&, T1, T2, T3, W, X, Y, Z, C, R
Arr = Range([¸ê®Æ!c1], [¸ê®Æ!a1].Cells(Rows.Count, 1).End(xlUp))
Set X = CreateObject("Scripting.Dictionary")
Set Y = CreateObject("Scripting.Dictionary")
Set W = CreateObject("Scripting.Dictionary")
For i = 2 To UBound(Arr)
   T1 = Arr(i, 1)
   T2 = Arr(i, 2)
   T3 = Format(Arr(i, 3), "0000")
   Y(T1) = ""
   X(T2 & "|" & T3) = ""
   W(T1 & "|" & T2 & "|" & T3) = T3
Next
ReDim Arr(1 To Y.Count + 1, 1 To X.Count + 1)
i = 1
For Each R In Y.KEYS
   i = i + 1
   Arr(i, 1) = R
   j = 1
   For Each C In X.KEYS
      j = j + 1
      Arr(i, j) = W(R & "|" & C)
      Arr(1, j) = IIf(i = 2, C, Arr(1, j))
   Next
Next
Arr(1, 1) = "¡@¡@¡@­ì®Æ¡@½s¸¹"
With [§e²{ªí!A1].Resize(UBound(Arr), UBound(Arr, 2))
    .Value = Arr
    .Columns(2).Resize(, UBound(Arr, 2)).Sort Key1:=.Cells(1, 2), Order1:=xlAscending, Header:=xlNo, Orientation:=xlLeftToRight
    .Rows(2).Resize(UBound(Arr)).Sort Key1:=.Cells(2, 1), Order1:=xlAscending, Header:=xlNo, Orientation:=xlTopToBottom
    .Rows(1).Replace "|*", "", Lookat:=xlPart
    .Borders.LineStyle = 1
End With
End Sub

TOP

        ÀR«ä¦Û¦b : µêªÅ¦³ºÉ¡D§ÚÄ@µL½a¡AµoÄ@®e©ö¦æÄ@Ãø¡C
ªð¦^¦Cªí ¤W¤@¥DÃD