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

½Ð°Ý¸ê®Æ¤ñ¹ï¥B¹Bºâ¨ì¤u§@ªí¤T

¥»©«³Ì«á¥Ñ Andy2483 ©ó 2023-5-24 11:04 ½s¿è

ÁÂÁ½׾Â,ÁÂÁ¦U¦ì«e½ú
«á¾ÇÂǦ¹©«½m²ß°}¦C»P¦r¨å,¾Ç²ß¤è®×¦p¤U,½Ð¦U¦ì«e½ú«ü±Ð

¤µ¤é¥æ©öªí & ¤µ¤é³ø»ùªí:
  

µ²ªGªí°õ¦æ«e:


°õ¦æµ²ªG:



Option Explicit
Sub TEST()
Dim Arr, Brr, Crr, Y, i&
'¡ô«Å§iÅܼÆ
Set Y = CreateObject("Scripting.Dictionary")
'¡ô¥OYÅܼƬO ¦r¨å
Brr = Range([¤µ¤é³ø»ù!B2], [¤µ¤é³ø»ù!A65536].End(3))
'¡ô¥OBrrÅܼƬO ¤Gºû°}¦C,¥H¤µ¤é³ø»ùªí Àx¦s®æ­È±a¤J°}¦C¸Ì
For i = 1 To UBound(Brr): Y(Brr(i, 1) & "/³ø") = Brr(i, 2): Next
'¡ô³]¶¶°j°é,¥O²£«~¦WºÙ ³s±µ "/³ø"·íkey,item¬OBÄ檺³ø»ù
Brr = Range([¤µ¤Ñ¥æ©ö!B2], [¤µ¤Ñ¥æ©ö!A65536].End(3))
'¡ô¥OBrrÅܼƬO ¤Gºû°}¦C,¥H¤µ¤Ñ¥æ©öªíÀx¦s®æ­È±a¤J°}¦C¸Ì
For i = 1 To UBound(Brr): Y(Brr(i, 1) & "/©ö") = Y(Brr(i, 1) & "/©ö") + Brr(i, 2): Next
'¡ô³]¶¶°j°é,¥O²£«~¦WºÙ ³s±µ "/©ö"·íkey,item¬OBÄ檺³æ¶q°µ²Ö¥[
Arr = Range([¥æ©ö¬ö¿ý!A1], [¥æ©ö¬ö¿ý!A65536].End(3))
'¡ô¥OArrÅܼƬO ¤Gºû°}¦C,¥H¥æ©ö¬ö¿ýªí AÄæÀx¦s®æ­È±a¤J°}¦C¸Ì
If [¥æ©ö¬ö¿ý!C1] = Date Then
'¡ô¦pªG[¥æ©ö¬ö¿ý!C1]Àx¦s®æ­È¬O ¤µ¤Ñ¤é´Á,¥Nªí¤µ¤é¤w¸g°õ¦æ¹L
   Crr = Range([¥æ©ö¬ö¿ý!V1], [¥æ©ö¬ö¿ý!C65536].End(3))
   '¡ô¥OCrrÅܼƬO ¤Gºû°}¦C,¥H¥æ©ö¬ö¿ýªíC~VÄæÀx¦s®æ­È±a¤J°}¦C
   Else '§_«h
      Crr = Range([¥æ©ö¬ö¿ý!V1], [¥æ©ö¬ö¿ý!B65536].End(3))
      '¡ô¥OCrrÅܼƬO ¤Gºû°}¦C,¥H¥æ©ö¬ö¿ýªíB~VÄæÀx¦s®æ­È±a¤J°}¦C
End If
For i = 2 To UBound(Crr)
'¡ô³]¶¶°j°é
   Crr(i, 1) = Y(Arr(i, 1) & "/³ø") * Y(Arr(i, 1) & "/©ö")
   '¡ô¥OCrr°}¦Cªº²Ä1Äæ±a¤J¬dY¦r¨å­pºâ¥X¨Óªº¨C­Ó²£«~¥æ©öª÷ÃB
Next
Crr(1, 1) = Date
'¡ô¥OCrr°}¦C1¯Á¤Þ¸¹¦C1¯Á¤Þ¸¹Äæ°}¦C­È¬O ¤µ¤Ñ¤é´Á
[¥æ©ö¬ö¿ý!C1].Resize(UBound(Crr), 20) = Crr
'¡ô¥OCrr°}¦C­È±q[¥æ©ö¬ö¿ý!C1]¶}©l¼g¤JÀx¦s®æ¸Ì
Set Y = Nothing: Erase Arr,Brr, Crr
'¡ô¥OÄÀ©ñÅܼÆ
End Sub
¥Î¦æ°Ê¸Ë¸mÂsÄý½×¾Â¾Ç²ß«Ü¤è«K,ÁÂÁ½׾¸gÀç¹Î¶¤
½Ð¤j®a¤@°_¤W½×¾Â¨Ó¥æ¬y

TOP

        ÀR«ä¦Û¦b : ­n¥Î¤ß¡A¤£­n¾Þ¤ß¡B·Ð¤ß¡C
ªð¦^¦Cªí ¤W¤@¥DÃD