- ©«¤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-3-24
|
ÁÂÁ½׾Â,ÁÂÁ¦U¦ì«e½ú
«á¾ÇÂǦ¹©«½m²ß°}¦C»P¦r¨å,¾Ç²ß¤è®×¦p¤U,½Ð¦U¦ì«e½ú«ü±Ð
°õ¦æ«e:
°õ¦æµ²ªG:
Option Explicit
Sub TEST() '¡ô
Dim Brr, Crr, V, Y, R&, i&
'¡ô «Å§iÅܼÆ
Set Y = CreateObject("Scripting.Dictionary")
'¡ô¥OYÅܼƬO¦r¨å
Brr = Range([B2], Cells(Rows.Count, 1).End(xlUp))
'¡ô¥OBrrÅܼƬO ¤Gºû°}¦C,¥HÀx¦s®æÈ±a¤J°}¦C¤¤
ReDim Crr(1 To 1000, 1 To 2)
'¡ô«Å§i CrrÅܼƬO¤GºûªÅ°}¦C,Áa¦V¯Á¤Þ¸¹1~1000,¾î¦V¯Á¤Þ¸¹1~2
For i = 1 To UBound(Brr)
'¡ô³]¶¶°j°é!i±q1¨ìBrrÁa¦V³Ì¤j¯Á¤Þ¦C¸¹
For Each V In Split(Brr(i, 2) & vbLf, vbLf)
'¡ô³]³v¶µ°j°é!¥OVÅܼƬO¥H´«¦æ¦r¤¸¤À³ÎBrr°}¦C²Ä2Äæ¦r¦êªº¤@ºû°}¦CȤ§¤@
If Trim(V) = "" Then GoTo v01
'¡ô¦pªGVÅܼƥh°£ÀY§ÀªÅ¦r¤¸«á¬O ªÅ¦r¤¸!´N¸õ¨ìv01¼Ð¥Ü¦ì¸mÄ~Äò°õ¦æ
If Y(Brr(i, 1) & "|" & V) <> "" Then GoTo v01
'¡ô¦pªGBrr°}¦C²Ä1Äæ¦r¦ê³s±µ"|",¦A³s±µVÅܼƩҲզ¨ªº¦r¦ê¬dY¦r¨åitemÈ,
'itemȤ£¬OªÅ¦r¤¸!´N¸õ¨ìv01¼Ð¥Ü¦ì¸mÄ~Äò°õ¦æ
R = R + 1: Y(Brr(i, 1) & "|" & V) = 1
'¡ô¥ORÅܼƲ֥[1
'¥O¦bY¦r¨å¸Ìªº(key:Brr°}¦C²Ä1Äæ¦r¦ê³s±µ"|",¦A³s±µVÅܼƩҲզ¨ªº¦r¦ê),
'item="" §ï¬° 1,
Crr(R, 1) = Brr(i, 1): Crr(R, 2) = V
'¡ô¥ORÅܼƦC²Ä1ÄæCrr°}¦C¬O i°j°é¦C²Ä1ÄæBrr°}¦CÈ,
'¡ô¥ORÅܼƦC²Ä2ÄæCrr°}¦C¬O VÅܼÆ
v01: Next
Next
[E2].Resize(R, 2) = Crr
'¡ô¥O[E2]ÂX®i¦V¤URÅܼƦC,¦V¥kÂX®i2Äæ½d³òÀx¦s®æÈ¥HCrr°}¦Cȱa¤J
Set Y = Nothing: Erase Brr, Crr
'¡ô¥OÄÀ©ñÅܼÆ
End Sub |
|