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

[µo°Ý] ¨âªí¸ê®Æ­«½Æ¹ï¤ñ¨Ã¼Æ¶q¬Û­¼

¦^´_  198188


    ½Ð«e½ú¦Û¦æ¸Õ¸Õ¼g¤@¬q¥N½X¥ý§âData ¦P¸¹¬Û¥[¡A¦A±NRead¤ñ¹ï2¦¸Data
Andy2483 µoªí©ó 2025-11-6 19:04
  1. Brr = [Read!A1].CurrentRegion
  2. For i = 2 To UBound(Brr): Z(Brr(i, 1)) = Val(Brr(i, 3)): Next
  3. N = 1
  4. For i = 2 To UBound(Brr)
  5.    If Z.Exists(Brr(i, 1)) Then
  6.           Z(Brr(N, 3)) = Z(Brr(N, 3)) + Brr(i, 3)
  7.       End If
  8. Next
½Æ»s¥N½X
§Ú¹Á¸Õ±N¦Ç¦âªº¼Æ¶q°O¤J¦r¨å¡AÀY¥|­Ó¦¨¥\°O¤J¡A¦ý¬O«á­±¤£À´±o¥[Á`¡A

TOP

¥»©«³Ì«á¥Ñ 198188 ©ó 2025-11-7 12:02 ½s¿è
¦^´_  198188


    ½Ð«e½ú¦Û¦æ¸Õ¸Õ¼g¤@¬q¥N½X¥ý§âData ¦P¸¹¬Û¥[¡A¦A±NRead¤ñ¹ï2¦¸Data
Andy2483 µoªí©ó 2025-11-6 19:04



  «e½ú¡A²Ä¤@¨B ±NRead ªíªº CODE ©ñ¤J¦r¨å¡AQty ¤]©ñ¤J¦r¨å¨Ã¬Û¦P Code ¥[Á`¡A³o³¡¤À§Ú¸Õ¤F«Ü¦h¦¸¡A³£¤£¦¨¥\¡C
½Ð«üÂI¤@¤U«á¾Ç¡C

TOP

¥»©«³Ì«á¥Ñ 198188 ©ó 2025-11-7 14:55 ½s¿è
  1. Sub sumdata()
  2. Dim i As Long
  3. Dim n As Long
  4. Dim ar, arr, brr As Variant
  5. Dim dict As New Dictionary

  6. ar = [A1].CurrentRegion
  7. Set dict = CreateObject("Scripting.Dictionary")

  8. With dict
  9. For i = 1 To UBound(ar, 1)
  10. .Item(ar(i, 1)) = .Item(ar(i, 1)) + ar(i, 3)
  11. Next i
  12. arr = Array(.Keys, .Items)
  13. n = .Count
  14. End With

  15. [O1].Resize(n, 2).Value = Application.Transpose(arr)


  16. brr = Sheets("Data").UsedRange
  17. For i = 2 To UBound(brr)
  18.    If dict(brr(i, 8)) > 0 Then
  19.       m = m + 1
  20.       For j = 1 To 13: brr(m, j) = brr(i, j): Next
  21.       brr(m, 3) = brr(m, 3) * dict(brr(i, 8))
  22.          
  23.    End If
  24. Next
  25. If m > 0 Then Sheets("Read").[A13].Resize(m, 13) = brr: m = 0 Else MsgBox "Frame per Dwg_Nothing"

  26. End Sub
½Æ»s¥N½X
¦^´_  198188


    ½Ð«e½ú¦Û¦æ¸Õ¸Õ¼g¤@¬q¥N½X¥ý§âData ¦P¸¹¬Û¥[¡A¦A±NRead¤ñ¹ï2¦¸Data
Andy2483 µoªí©ó 2025-11-6 19:04


«e½ú¡A§Ú§¹¦¨²Ä¤@½ü¤F¡C

TOP

¦^´_  198188


    ½Ð«e½ú¦Û¦æ¸Õ¸Õ¼g¤@¬q¥N½X¥ý§âData ¦P¸¹¬Û¥[¡A¦A±NRead¤ñ¹ï2¦¸Data
Andy2483 µoªí©ó 2025-11-6 19:04
  1. Sub sumdata()
  2. Dim i As Long
  3. Dim n As Long
  4. Dim ar, arr, brr As Variant
  5. Dim dict As New Dictionary
  6. .Column("O:P").Delete
  7. ar = [A1].CurrentRegion
  8. lastRow = UBound(ar)
  9. Set dict = CreateObject("Scripting.Dictionary")

  10. With dict
  11. For i = 1 To UBound(ar, 1)
  12. .Item(ar(i, 1)) = .Item(ar(i, 1)) + ar(i, 3)
  13. Next i
  14. arr = Array(.Keys, .Items)
  15. n = .Count
  16. End With
  17. [O1].Resize(n, 2).Value = Application.Transpose(arr)

  18. brr = Sheets("Data").UsedRange
  19. For i = 2 To UBound(brr)
  20.    If dict(brr(i, 8)) > 0 Then
  21.       m = m + 1
  22.       For j = 1 To 13: brr(m, j) = brr(i, j): Next
  23.       brr(m, 3) = brr(m, 3) * dict(brr(i, 8))
  24.    
  25.    End If
  26. Next
  27. If m > 0 Then Sheets("Read").Range("A" & lastRow + 1).Resize(m, 13) = brr: m = 0

  28. ar = Range("A" & lastRow + 1).CurrentRegion
  29. lastRow1 = UBound(ar)
  30. ar = Range("A" & lastRow & ":M" & lastRow1)
  31. Set dict = CreateObject("Scripting.Dictionary")

  32. With dict
  33. For i = 2 To UBound(ar, 1)
  34. .Item(ar(i, 1)) = .Item(ar(i, 1)) + ar(i, 3)
  35. Next i
  36. arr = Array(.Keys, .Items)
  37. n = .Count
  38. End With
  39. [O1].Resize(n, 2).Value = Application.Transpose(arr)

  40. brr = Sheets("Data").UsedRange
  41. For i = 1 To UBound(brr)
  42.    If dict(brr(i, 8)) > 0 Then
  43.       m = m + 1
  44.       For j = 1 To 13: brr(m, j) = brr(i, j): Next
  45.       brr(m, 3) = brr(m, 3) * dict(brr(i, 8))
  46.    
  47.    End If
  48. Next
  49. If m > 0 Then Sheets("Read").Range("A" & lastRow1 + 1).Resize(m, 13) = brr: m = 0

  50. End Sub
½Æ»s¥N½X
«e½ú¡A¤w¸g§¹¦¨¡A½Ð«üÂI¡C

TOP

¦^´_ 9# 198188


    ³o¦nÃø,¤£ª¾¹D¹ï¤£¹ï,½Ð«e½ú«ü±Ð

°õ¦æµ²ªG:


Option Explicit
Sub TEST1()
Dim brr, X, Y, Z, K, Q, i&, j%, n&, T1$, T8$
Set Z = CreateObject("Scripting.Dictionary")
Set Y = CreateObject("Scripting.Dictionary")
Set X = CreateObject("Scripting.Dictionary")
brr = Sheets(1).[A1].CurrentRegion
For i = 2 To UBound(brr)
   If Y(brr(i, 1)) = "" Then
      Y(brr(i, 1)) = "(" & Val(brr(i, 3))
      Else
      Y(brr(i, 1)) = Y(brr(i, 1)) & "+" & Val(brr(i, 3))
   End If
Next
brr = Sheets(2).[A1].CurrentRegion
For i = 2 To UBound(brr)
   T1 = brr(i, 1)
   T8 = brr(i, 8)
   If Y.Exists(T8) Then
      If Not IsObject(Z(T8 & "/")) Then
         Set Z(T8 & "/") = CreateObject("Scripting.Dictionary")
         brr(i, 3) = Y(T8) & ")*(" & Val(brr(i, 3))
         Z(T1) = brr(i, 3)
         Else
         Z(T1) = Z(T8) & "+" & Val(brr(i, 3))
         brr(i, 3) = Y(T8) & ")*(" & Val(brr(i, 3))
      End If
      Z(T8 & "/")(i) = ""
      Z(T8) = brr(i, 3)
   End If
Next
For i = 2 To UBound(brr)
   T1 = brr(i, 1)
   T8 = brr(i, 8)
   If Z.Exists(T8) And Not Y.Exists(T8) Then
      If Not IsObject(Z(T8 & "/")) Then
         Set Z(T8 & "/") = CreateObject("Scripting.Dictionary")
         brr(i, 3) = Z(T8) & ")*(" & Val(brr(i, 3))
         X(T1) = brr(i, 3)
         Else
         X(T1) = X(T8) & "+" & Val(brr(i, 3))
         brr(i, 3) = Z(T8) & ")*(" & Val(brr(i, 3))
      End If
      Z(T8 & "/")(i) = ""
      X(T8) = brr(i, 3)
   End If
Next
For Each K In Z.Keys
   If IsObject(Z(K)) Then
      For Each Q In Z(K).Keys
         n = n + 1
         For j = 1 To UBound(brr, 2): brr(n, j) = brr(Q, j): Next
         brr(n, 3) = brr(n, 3) & ")": 'Brr(N, 3) = "=" & Brr(N, 3)
      Next
   End If
Next
If n > 0 Then Workbooks.Add: [A1].Resize(n, UBound(brr, 2)) = brr
End Sub
¥Î¦æ°Ê¸Ë¸mÂsÄý½×¾Â¾Ç²ß«Ü¤è«K,ÁÂÁ½׾¸gÀç¹Î¶¤
½Ð¤j®a¤@°_¤W½×¾Â¨Ó¥æ¬y

TOP

¦^´_ 14# 198188


    ÁÂÁ«e½ú«ü¾É,«Ü¦h¨S¬Ý¹Lªº,«á¾Ç°õ¦æ¥X²{°»¿ù,½Ð«e½ú«üÂI

¥Î¦æ°Ê¸Ë¸mÂsÄý½×¾Â¾Ç²ß«Ü¤è«K,ÁÂÁ½׾¸gÀç¹Î¶¤
½Ð¤j®a¤@°_¤W½×¾Â¨Ó¥æ¬y

TOP

¥»©«³Ì«á¥Ñ 198188 ©ó 2025-11-7 17:44 ½s¿è
¦^´_  198188


    ÁÂÁ«e½ú«ü¾É,«Ü¦h¨S¬Ý¹Lªº,«á¾Ç°õ¦æ¥X²{°»¿ù,½Ð«e½ú«üÂI
Andy2483 µoªí©ó 2025-11-7 16:40



   

«e½ú¡A»Ý­n¥h ¤u¨ã =>³]©w¤Þ¥Î¶µ¥Ø => Microsoft Scripting Runtime
ªþ¤W½d¨Ò

½d¨Ò.rar (12.52 KB)

TOP

        ÀR«ä¦Û¦b : ÁÀ¨¥¹³¤@¦·²±¶}ªºÂAªá¡A¥~ªí¬üÄR¡A¥Í©Rµu¼È¡C
ªð¦^¦Cªí ¤W¤@¥DÃD