返回列表 上一主題 發帖

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

回復 10# GBKEE


這些是我重複的
$1806:$1810,$1800:$1802,$1798:$1798,$1794:$1795,$1791:$1792,$1788:$1789,$1785:$1785,$1772:$1772,$1764:$1764,$1754:$1758,$1748:$1750,$1743:$1743,$1739:$1740,$1736:$1737,$1733:$1734,$1730:$1730,$1718:$1718,$1710:$1710,$1698:$1701,$1691:$1691,$1688:$1689


如有重複我只要刪除重複的部分
留唯一

還是板大的程式把重複的全刪了???

我也不確定是不是

麻煩大大幫我看看

謝謝你
用功到世界末日那一天~~~

TOP

本帖最後由 Hsieh 於 2014-1-22 16:43 編輯

回復 1# li_hsien
  1. Sub ex()
  2. Dim Ar
  3. Set d = CreateObject("Scripting.Dictionary")
  4. With Sheets("產品管控清單")
  5. Ar = .UsedRange.Value
  6. For i = 2 To UBound(Ar, 1) '記錄產品不重覆記錄
  7.    d(Ar(i, 10)) = Array(Ar(i, 5), Ar(i, 6), Ar(i, 7), Ar(i, 8), Ar(i, 9), Ar(i, 10), Ar(i, 3), Ar(i, 1), Ar(i, 2))
  8. Next
  9. End With
  10. With Sheets("物料管控清單")
  11. Ar = .UsedRange.Value
  12. For i = 2 To UBound(Ar, 1)
  13.    If d.exists(Ar(i, 6)) Then
  14.      .Cells(i, 1).Resize(, 9) = d(Ar(i, 6)) '產品出現在物料則更新為產品資料
  15.       d.Remove Ar(i, 6) '移除已寫入的資料
  16.    End If
  17. Next
  18. '若產品未出現於物料,則新增至物料資料尾
  19. If d.Count > 0 Then .Cells(.Rows.Count, 1).End(xlUp).Offset(1).Resize(d.Count, 9) = Application.Transpose(Application.Transpose(d.items))
  20. End With
  21. End Sub
複製代碼
forum01.22.zip (126.27 KB)
學海無涯_不恥下問

TOP

回復 12# Hsieh


謝謝H板大的解答

不過測試了一下

我發現如果我在"產品"那邊刪除一筆,再次執行

"物料"那並不會刪除耶

好像還是有點問題

麻煩板大幫我看看

謝謝:  )
用功到世界末日那一天~~~

TOP

回復 10# GBKEE

GB板大,如果我不做重複的處理

直接做"產品"跟"物料"的新增刪除修改

改成以下方式可行嗎???

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


但我測試幾次,如果在"產品"的表單中加入一筆新的

可能無法在"物料"中顯示

在最下端增加好像才不會出錯


麻煩板大幫我看看程式還需做怎樣的修改

謝謝你  :  )
  1. Sub Ex2()
  2.     Dim d As New Collection, AR(1 To 7), i As Integer, Rng As Range, E As Variant
  3.     On Error Resume Next              'Collection新增的KEY如被使用或有錯誤
  4.     With Worksheets("產品管控清單")
  5.         For i = 2 To .Range("J1").End(xlDown).Row
  6.             AR(1) = .Range("E" & i)             'PRODUCT ID(A)
  7.             AR(2) = .Range("F" & i)             'CHILDPARTNUMBER(B)
  8.             AR(3) = .Range("C" & i)             'MP date(G)
  9.             AR(4) = .Range("A" & i)             '週別(H)
  10.             AR(5) = .Range("B" & i)             '更新週別(I)
  11.             AR(6) = DateDiff("d", Date, AR(3))  '工作日(M)
  12.             AR(7) = .Range("J" & i)             'Product ID & PartNumber(F)
  13.             d.Add AR, .Range("J" & i).Value
  14.         Next
  15.     End With
  16.     With Worksheets("物料管控清單")
  17.         For Each E In .Range("F:F").SpecialCells(xlCellTypeConstants).Offset(1)
  18.             .Range("A" & E.Row) = d(E.Value)(1)
  19.             .Range("B" & E.Row) = d(E.Value)(2)
  20.             .Range("G" & E.Row) = d(E.Value)(3)
  21.             .Range("H" & E.Row) = d(E.Value)(4)
  22.             .Range("I" & E.Row) = d(E.Value)(5)
  23.             .Range("M" & E.Row) = d(E.Value)(6)
  24.             .Range("F" & E.Row) = d(E.Value)(7)
  25.             If Err = 0 Then                     '物料的ID & PartNumber,存在產品的ID & PartNumber中
  26.                 d.Remove E.Value                '除去:產品的ID & PartNumber

  27.             ElseIf Err <> 0 And E <> "" Then    '物料的ID & PartNumber,不存在產品的ID & PartNumber中
  28.                 If Rng Is Nothing Then       '取的儲存格的位置
  29.                     Set Rng = E
  30.                 Else
  31.                     [color=Red]Set Rng = Union(E, Rng)[/color]
  32.                     [color=Red]Rng.EntireRow.Delete[/color]
  33.                 End If
  34.             End If
  35.             Err.Clear
  36.         Next
  37.         If d.Count > 0 Then                     '補上:物料沒有的產品ID & PartNumber
  38.             i = 0
  39.             With .Range("A1").End(xlDown)
  40.                 For Each E In d
  41.                     i = i + 1
  42.                     .Offset(i).Range("A1") = E(1)
  43.                     .Offset(i).Range("B1") = E(2)
  44.                     .Offset(i).Range("G1") = E(3)
  45.                     .Offset(i).Range("H1") = E(4)
  46.                     .Offset(i).Range("I1") = E(5)
  47.                     .Offset(i).Range("M1") = E(6)
  48.                     .Offset(i).Range("F1") = E(7)
  49.                 Next
  50.             End With
  51.         End If
  52.     End With
複製代碼
用功到世界末日那一天~~~

TOP

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

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

TOP

回復 15# Hsieh

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

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

欄位也不盡相同

但有些部分一樣

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


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

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

不需要好幾欄&起來比對


不過因為我用FOR再跑

所以資料量好大

想尋求快速的比對方式


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

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

回復 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

回復 17# GBKEE

大大你也太神奇了

真的100筆以下就OK耶@@

為什麼會這樣啊


不過我不能只有這麼幾筆

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

TOP

回復 19# li_hsien

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


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

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

TOP

        靜思自在 : 人生沒有所有權,只有生命的使用權。
返回列表 上一主題