返回列表 上一主題 發帖

[發問] 改善大筆資料處理

[發問] 改善大筆資料處理

請問各位大大

小弟我目前有兩個工作表

依據"產品工作表"(A) 的 ID & PartNumber 比對到 "物料工作表"(B) 的 ID & PartNumber

如果有一樣的,則把A的資料COPY到B裡面

如果沒有相同的,則補到B的最下方


資料量小的時候還可以

但我資料有幾千筆會變好慢好慢 大約要跑10分鐘左右

可能是FOR迴圈的問題

不知有什麼改善方法

麻煩各位大大

以下為附檔

P.S. 比對欄位有刪減,所以附檔的處理速度好像還可以

forum.zip (118.3 KB)
用功到世界末日那一天~~~

回復 22# GBKEE

新增修改正常了

感謝版大不厭其煩的熱心幫助  :  )
用功到世界末日那一天~~~

TOP

回復 21# li_hsien
試試看
9#所說: 最後結果是"產品"跟"物料"的項目數會是一樣的沒有錯
  1. Option Explicit
  2. Sub Ex()
  3.     Dim d As New Collection, AR(), i As Integer, Rng As Range ', e As Variant
  4.     On Error Resume Next              'Collection新增的KEY如被使用或有錯誤
  5.     With Worksheets("產品管控清單")
  6.         For i = 2 To .Range("J1").End(xlDown).Row
  7.             AR = Application.Transpose(Application.Transpose(.Range("A" & i).Resize(, 10)))
  8.             '******  產品(A:J)欄位資料導入陣列  ****
  9.             '1:產品欄位週別 ,2'產品欄:更新週別,3:MP date,4:產品類別,5:PRODUCT ID,
  10.             '6:CHILDPARTNUMBER,7:CHILD_DESCRIPTION,8:Maker,9:MAKER & CODE.10:ID & PartNumber
  11.             d.Add AR, .Range("J" & i)     '
  12.             '*****找出[產品管控清單]重複的[ID & PartNumber]  ****
  13.             If Err <> 0 Then
  14.                 If Rng Is Nothing Then
  15.                     Set Rng = .Range("J" & i)
  16.                 Else
  17.                     Set Rng = Union(.Range("J" & i), Rng)
  18.                 End If
  19.             End If
  20.             Err.Clear
  21.             '*****************************************************
  22.         Next
  23.     End With
  24.     On Error GoTo 0              '不再處裡程式的錯誤
  25.     If Not Rng Is Nothing Then Rng.EntireRow.Delete
  26.     With Worksheets("物料管控清單")
  27.         .UsedRange.Offset(1).Clear
  28.         For i = 1 To d.Count
  29.             With .Range("A" & i + 1)
  30.              '產品欄位
  31.              '1:產品欄位週別 ,2'產品欄:更新週別,3:MP date,4:產品類別,5:PRODUCT ID,
  32.              '6:CHILDPARTNUMBER,7:CHILD_DESCRIPTION,8:Maker,9:MAKER & CODE.10:ID & PartNumber
  33.                 .Range("A1") = d(i)(5)   '導入物品欄位A1-M1
  34.                 .Range("B1") = d(i)(6)
  35.                 .Range("C1") = d(i)(7)
  36.                 .Range("D1") = d(i)(8)
  37.                 .Range("E1") = d(i)(9)
  38.                 .Range("F1") = d(i)(10)
  39.                 .Range("G1") = Format(d(i)(3), "YYYY/M/D")
  40.                 .Range("H1") = d(i)(2)
  41.                 .Range("I1") = d(i)(1)
  42.                 .Range("M1") = DateDiff("d", Date, .Range("G1"))  '工作日(M)
  43.             End With
  44.         Next
  45.     End With
  46.     MsgBox d.Count & "項 OK"
  47. End Sub
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 20# GBKEE

真的是這個錯誤耶!!!!



我以為有了On Error Resume Next就可以排除了@@

不過資料增加和刪除的部分有辦法修正嗎????

因為可能從"產品"的資訊中間新增或刪除,而不是在下方

可是現在測試的結果,如果在中間新增會有錯誤,新增不到的問題


感謝大大的發現  !!!!!!!
用功到世界末日那一天~~~

TOP

回復 19# li_hsien

   
正常應該剩1206項但刪除後卻只剩1194項,好奇怪喔@@


C欄日期格式不對導致的!!!

感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 17# GBKEE

大大你也太神奇了

真的100筆以下就OK耶@@

為什麼會這樣啊


不過我不能只有這麼幾筆

不知能否克服???
用功到世界末日那一天~~~

TOP

回復 17# GBKEE

謝謝板大再次幫我修改

我再測試一次還是會多刪除耶

以下是我用大大程式碼修改後的
  1. Option Explicit

  2. Sub Ex()
  3.     Dim d As New Collection, AR(1 To 7), i As Integer, Rng(1 To 2) As Range, E As Variant
  4.     On Error Resume Next              'Collection新增的KEY如被使用或有錯誤
  5.     With Worksheets("產品管控清單")
  6.         For i = 2 To .Range("J1").End(xlDown).Row
  7.             AR(1) = .Range("E" & i)             'PRODUCT ID(A)
  8.             AR(2) = .Range("F" & i)             'CHILDPARTNUMBER(B)
  9.             AR(3) = .Range("C" & i)             'MP date(G)
  10.             AR(4) = .Range("A" & i)             '週別(H)
  11.             AR(5) = .Range("B" & i)             '更新週別(I)
  12.             AR(6) = DateDiff("d", Date, AR(3))  '工作日(M)
  13.             AR(7) = .Range("J" & i)             'Product ID & PartNumber(F)
  14.             d.Add AR, .Range("J" & i).Value
  15.             '*****找出[產品管控清單]重複的[ID & PartNumber]  ****
  16.             If Err <> 0 Then
  17.                 Err.Clear
  18.                 If Rng(1) Is Nothing Then
  19.                     Set Rng(1) = .Range("J" & i)
  20.                 Else
  21.                     Set Rng(1) = Union(.Range("J" & i), Rng(1))
  22.                 End If
  23.             End If
  24.             '*****************************************************
  25.         Next
  26.     End With
  27.     With Worksheets("物料管控清單")
  28.         For Each E In .Range("F:F").SpecialCells(xlCellTypeConstants).Offset(1)
  29.             .Range("A" & E.Row) = d(E.Value)(1)
  30.             .Range("B" & E.Row) = d(E.Value)(2)
  31.             .Range("G" & E.Row) = d(E.Value)(3)
  32.             .Range("H" & E.Row) = d(E.Value)(4)
  33.             .Range("I" & E.Row) = d(E.Value)(5)
  34.             .Range("M" & E.Row) = d(E.Value)(6)
  35.             .Range("F" & E.Row) = d(E.Value)(7)
  36.             If Err = 0 Then                     '物料的ID & PartNumber,存在產品的ID & PartNumber中
  37.                 d.Remove E.Value                '除去:產品的ID & PartNumber
  38.             ElseIf Err <> 0 And E <> "" Then    '物料的ID & PartNumber,不存在產品的ID & PartNumber中
  39.                 If Rng(2) Is Nothing Then       '取的儲存格的位置
  40.                     Set Rng(2) = E
  41.                 Else
  42.                     Set Rng(2) = Union(E, Rng(2))
  43.                 End If
  44.             End If
  45.             Err.Clear
  46.         Next
  47.         If d.Count > 0 Then                     '補上:物料沒有的產品ID & PartNumber
  48.             i = 0
  49.             With .Range("A1").End(xlDown)
  50.                 For Each E In d
  51.                     i = i + 1
  52.                     .Offset(i).Range("A1") = E(1)
  53.                     .Offset(i).Range("B1") = E(2)
  54.                     .Offset(i).Range("G1") = E(3)
  55.                     .Offset(i).Range("H1") = E(4)
  56.                     .Offset(i).Range("I1") = E(5)
  57.                     .Offset(i).Range("M1") = E(6)
  58.                     .Offset(i).Range("F1") = E(7)
  59.                 Next
  60.             End With
  61.         End If
  62.     End With
  63.    
  64. '    '********* "產品管控清單" 刪除重複的[ID & PartNumber]*******************
  65. '    If Not Rng(1) Is Nothing Then
  66. '        If MsgBox("刪除重複的[ID & PartNumber]", vbQuestion + vbYesNo, "產品管控清單") = vbYes Then
  67. '            Rng(1).EntireRow.Delete
  68. '        End If
  69. '    End If
  70.    
  71. '    '********* "產品管控清單" 刪除重複的[ID & PartNumber]*******************
  72. '    If Not Rng(1) Is Nothing Then
  73. '        If MsgBox("刪除重複的[ID & PartNumber]", vbQuestion + vbYesNo, "產品管控清單") = vbYes Then
  74. '             Worksheets("產品管控清單").Activate
  75. '            Stop                                            '程式會停止 按F8一步一步執行下去看工作表的情形
  76. '            Rng(1).EntireRow.Select                  '選取重複的ID
  77. '            MsgBox Rng(1).EntireRow.Address
  78. '            Debug.Print Rng(1).EntireRow.Address
  79. ''            Rng(1).EntireRow.Delete   '先註解掉不刪除
  80. '        End If
  81. '    End If
  82.    
  83.    
  84.     If Not Rng(1) Is Nothing Then
  85.     '**** 刪除"產品"重複的部分->Rng(1)
  86.         If MsgBox("刪除重複的[ID & PartNumber]", vbQuestion + vbYesNo, "產品管控清單") = vbYes Then
  87.             Rng(1).Interior.Color = vbGreen    '重複的標註為綠色
  88.             For Each E In Rng(1).Areas
  89.                 For i = 1 To E.Cells.Count
  90.                     Set Rng(3) = Rng(1).EntireColumn.Find(E.Cells(i), LookIn:=xlValues)
  91.                     If Application.Intersect(Rng(1), Rng(3)) Is Nothing Then
  92.                         Rng(3).Interior.Color = vbRed      '保留第一筆重複的標註紅色
  93.                     End If
  94.                 Next
  95.             Next
  96.           '  Rng(1).EntireRow.Delete  先不刪除去看看有保留在哪裡
  97.         End If
  98.     End If
  99.    
  100.    
  101.     '********* "物料管控清單" 刪除重複的[ID & PartNumber]*******************
  102.     If Not Rng(2) Is Nothing Then
  103.         If MsgBox("刪除重複的[ID & PartNumber]", vbQuestion + vbYesNo, "物料管控清單") = vbYes Then
  104.           'Rng(2).EntireRow.Select
  105.            Rng(2).EntireRow.Delete
  106.         End If
  107.     End If
  108.     MsgBox "Ok"
  109. End Sub
複製代碼
應該是這樣改沒有錯吧


但我跑出來"產品"那邊一樣是多刪除

正常應該剩1206項但刪除後卻只剩1194項

好奇怪喔@@


大大說新增的部分

因為我的"產品"是由兩張工作表合而為一的

所以新增是分別在兩張工作表做的

所以新增的資訊可能會在"產品"的中間部分

不是在"產品"的最下方



請問大大

我能先處理刪除重複

那單純只做"產品","物料"資訊的新增刪除修改嗎???

這樣是否比較沒這麼複雜
(就去除掉排除重複的步驟,其餘都一樣)



以上 麻煩大大  參酌  謝謝  :   )
用功到世界末日那一天~~~

TOP

回復 16# li_hsien
11#說: 還是板大的程式把重複的全刪了???
給你驗正一下
  1. If Not Rng(1) Is Nothing Then
  2.     '**** 刪除"產品"重複的部分->Rng(1)
  3.         If MsgBox("刪除重複的[ID & PartNumber]", vbQuestion + vbYesNo, "產品管控清單") = vbYes Then
  4.             Rng(1).Interior.Color = vbGreen    '重複的標註為綠色
  5.             For Each E In Rng(1).Areas
  6.                 For i = 1 To E.Cells.Count
  7.                     Set Rng(3) = Rng(1).EntireColumn.Find(E.Cells(i), LookIn:=xlValues)
  8.                     If Application.Intersect(Rng(1), Rng(3)) Is Nothing Then
  9.                         Rng(3).Interior.Color = vbRed      '保留第一筆重複的標註紅色
  10.                     End If
  11.                 Next
  12.             Next
  13.           '  Rng(1).EntireRow.Delete  先不刪除去看看有保留在哪裡
  14.         End If
  15.     End If
複製代碼
你說:在最下端增加好像才不會出錯
程式有註解 [ 補上:物料沒有的產品ID & PartNumber ]   -> 就是最後補上的
那你想如何補上??
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 15# Hsieh

"產品"那邊的工作表還是需要保留著

因為"產品"跟"物料"的資訊不太一樣

欄位也不盡相同

但有些部分一樣

那它主要對應的方式都是依據ID & PAERTNUMBER


對了!!!
其實跟之前H版大幫我處理的<兩工作表比對 新增修改>這篇是一樣的

只是我後來應該方便作業所以多產生了一個ID & PAERTNUMBER來比對

不需要好幾欄&起來比對


不過因為我用FOR再跑

所以資料量好大

想尋求快速的比對方式


麻煩各位大大們   謝謝  :   )
用功到世界末日那一天~~~

TOP

回復 14# li_hsien
模式一樣是以"產品"為主
如果
"產品"有   "物料"有  則把"產品"  放到  "物料" 原有的位置
"產品"無   "物料"有  則把"物料" 那筆整欄刪掉
"產品"有   "物料"無  則把新增出來的那筆"產品"資訊 新增到"物料"的最下方

這樣不就只是把產品刪除重覆的結果而已嗎?
學海無涯_不恥下問

TOP

        靜思自在 : 稻穗結得越飽滿,越會往下垂,一個人越有成就,就要越有謙沖的胸襟。
返回列表 上一主題