¬O§_¥i¨Ï¥Î¤½¦¡¦Û°Ê°µ¤@²³æ®Ö®ø©ú²Óªí???
- ©«¤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-5-5
|
ÁÂÁ½׾Â,ÁÂÁ¦U¦ì«e½ú
«á¾ÇÂǦ¹©«½m²ß°}¦C»P¦r¨å,¾Ç²ß¤è®×¦p¤U,½Ð¦U¦ì«e½ú«ü±Ð
¸ê®Æªí:(¥X³f©ú²Ó)
µ²ªGªí°õ¦æ«e:
°õ¦æµ²ªG:
Option Explicit
Sub TEST()
Dim Brr, Crr, Y, i&, T$, Sh(2)
'¡ô«Å§iÅܼÆ
Set Y = CreateObject("Scripting.Dictionary")
'¡ô¥OYÅܼƬO ¦r¨å
Set Sh(1) = Sheets("¥¼µ²q³æ"): Set Sh(2) = Sheets("¥X³f©ú²Ó")
'¡ô¥OSh³o¤@ºû°}¦C1~2¯Á¤Þ¸¹È¦U¥H¤u§@ªí±a¤J
Brr = Sh(1).[A1].CurrentRegion: Crr = Sh(2).[A1].CurrentRegion
'¡ô¥OBrr,CrrÅܼƦU¬O¤Gºû°}¦C,¦U¥HÀx¦s®æÈ±a¤J°}¦C¤¤
For i = 2 To UBound(Crr)
T = Crr(i, 1) & "|" & Crr(i, 2): Y(T) = Y(T) + Crr(i, 3)
Next
'¡ô³]°j°é²Õ¦X(q³æ³æ¸¹|®Æ¸¹)·s¦r¦ê·íkey,item¬O¼Æ¶q²Ö¥[,¯Ç¤JY¦r¨å¸Ì
For i = 2 To UBound(Brr)
T = Brr(i, 1) & "|" & Brr(i, 2): Brr(i - 1, 1) = Brr(i, 3) - Y(T)
Next
'¡ô³]°j°é±N(q³æ³æ¸¹|®Æ¸¹)²Õ¦X¦¨ªº·s¦r¦ê¬dY¦r¨å±o¨ìitemÈ,
'·í³Q´î¼Æ°µ¦©°£,¼g¤JBrr°}¦Cªº²Ä1Äæ
Sh(1).[D2].Resize(UBound(Brr) - 1, 1) = Brr
'¡ô±NBrr°}¦Cȼg¤J"¥¼µ²q³æ"ªíµ²ªGÄæ¤¤
Application.Goto Sh(1).[D2].Resize(UBound(Brr) - 1, 1)
'¡ô¥OÀx¦s®æ´å¼Ð¸õ¨ì "¥¼µ²q³æ"ªíµ²ªGÄæ¤¤
Set Y = Nothing: Erase Brr, Crr, Sh
'¡ô¥OÄÀ©ñÅܼÆ
End Sub |
|
¥Î¦æ°Ê¸Ë¸mÂsÄý½×¾Â¾Ç²ß«Ü¤è«K,ÁÂÁ½׾¸gÀç¹Î¶¤
½Ð¤j®a¤@°_¤W½×¾Â¨Ó¥æ¬y
|
|
|
|
|