- ©«¤l
- 5923
- ¥DÃD
- 13
- ºëµØ
- 1
- ¿n¤À
- 5986
- ÂI¦W
- 0
- §@·~¨t²Î
- win10
- ³nÅ骩¥»
- Office 2010
- ¾\ŪÅv
- 150
- ©Ê§O
- ¨k
- ¨Ó¦Û
- ¥xÆW°ò¶©
- µù¥U®É¶¡
- 2010-5-1
- ³Ì«áµn¿ý
- 2022-1-23
        
|
¦^´_ 2# kuhsuanchieh
¸Õ¸Õ¬Ý- Option Explicit
- Sub Ex()
- Dim D As Object, AR As Variant, i As Long, XPath As String, Wb As String
- Set D = CreateObject("SCRIPTING.DICTIONARY") '¦r¨åª«¥ó
- '±N³o¨ÇÀɮצX¨Ö¼g¨ì¤@ÓÀɮ׸̡]¨Ò¦p¡GDATA¡^¡A
- '¥Ø«e¦³¼ÆÓ³sÄò½s¸¹ªºÀɮס]¨Ò¦p¡Gtest_1¡@¨ì¡@10¡^¡A
- XPath = "d:\test\ " '³]¦³¼ÆÓ³sÄò½s¸¹ªºÀɮצs©ó¦P¤@¸ê®Æ§¨
- Wb = Dir(XPath & "Test_*.xls") '¬d¸ß«ü©w©Ò»ÝªºÀÉ®×
- Application.ScreenUpdating = False
- Do While Wb <> "" '¬d¸ß¨ì©Ò»ÝªºÀÉ®×
- With Workbooks.Open(XPath & Wb).Sheets(1).UsedRange
- '¶}±ÒÀɮײĤ@Ó¤u§@ªíªº¨Ï¥Î½d³ò
- For i = 2 To .Rows.Count '²Ä2¦C¨ì³Ì«á¤@¦C
- With .Rows(i)
- AR = Array(.Cells(1, "c"), .Cells(1, "L"), .Cells(1, "D"), .Cells(1, "M"), .Cells(1, "F"))
- 'Ū¨ú C,L,D,M,F Äæ¦ì¸ê®Æ
- D(Join(AR, ",")) = "" '¼g¤J¦r¨åª«¥óªºKeyÈ
- End With
- Next
- .Parent.Parent.Close 'Ãö³¬¶}±ÒªºÀÉ®×
- '.UsedRangeªº[Parent]-> .Sheets(1)ªº[Parent] -> Workbooks
- End With
- Wb = Dir '¤U¤@Ó ¬d¸ßªºÀÉ®×
- Loop
-
- '¦p[DATA.xlsx] ¥¼¶}±Ò¥Î¤U¦¡µ{¦¡½X
- 'With Workbooks.Open(XPath & "\" & DATA.xlsx).Sheets(1)
-
- With Workbooks("DATA.xlsx").Sheets(1)
- For i = 2 To .UsedRange.Rows.Count
- AR = Application.Transpose(Application.Transpose(.UsedRange.Rows(i).Value))
- If D.exists(Join(AR, ",")) Then D.Remove Join(AR, ",")
- '¦r¨åª«¥ó Remove ¤èªk,±q¤@Ó Dictionary ª«¥ó¤¤²¾°£¤@ÓÃöÁä¦r©M¶µ¥Ø¹ï¡C
- Next
- For Each AR In D.keys '²¾°£¬Û¦PKey(ÃöÁä¦r)«á³Ñ¤UªºD.keys
- i = .[A1].End(xlDown).Row
- i = IIf(i = .Rows.Count, 2, i + 1) 'i=³Ì«á¤@¦Cªº¦C¼Æ,i=2,§_i+1
- With .Cells(i, "A").Resize(, 5)
- .Value = Split(AR, ",")
- .Cells(5).NumberFormatLocal = "[>99999999]0000-000-000;000-000-000"
- .Value = .Value '¼Æ¦r¬°¤å¦r®æ¦¡Âର¼Æ¦r®æ¦¡
- End With
- Next
- .Save '¦sÀÉ
- End With
- Application.ScreenUpdating = True
- End Sub
½Æ»s¥N½X |
|