返回列表 上一主題 發帖

[發問] 多條件篩選&ListBox

回復 119# c_c_lai


    換我眼花了我沒看到這行哈哈...
    剛剛測試過了!!
    沒錯哈哈~

TOP

回復 120# c_c_lai

附檔中我有加入這個按鈕
如果比對相同的話
我會秀那一欄的機台"編號"
口誤啦Q0Q

  1. Private Sub CommandButton2_Click()
  2. Sheets("量大未排機").Select
  3. Dim Arr, i&, Brr, aa, j&, x$, Myr&

  4. Dim d, k, t

  5. Set d = CreateObject("Scripting.Dictionary")

  6. Sheets("量大未排機").Activate
  7. '比對"TR排機&產出" 灰色欄位"E""F""G""H"比對"量大未排機"找到一樣的,秀上"TR排機&產出"的"B"欄同一列的機台編號
  8. With Sheets("TR排機&產出")

  9.     Myr = .Cells(.Rows.Count, 12).End(xlUp).Row

  10.     Arr = .Range("a1:p" & Myr)

  11. End With

  12. For i = 4 To UBound(Arr) Step 5

  13.     If Not IsError(Arr(i, 5)) Then   '& "|" & Arr(i, 6) & "|" & Arr(i, 7) & "|" & Arr(i, 8)

  14.     x = Arr(i, 5) & "|" & Arr(i, 6) & "|" & Arr(i, 7) & "|" & Arr(i, 8)

  15.     d(x) = d(x) & i & ","

  16.     End If

  17. Next

  18. Brr = [a1].CurrentRegion
  19.    
  20. For i = 2 To UBound(Brr) Step 5

  21.    x = Brr(i, 1) & "|" & Brr(i, 2) & "|" & Brr(i, 3) & "|" & Brr(i, 4)

  22.   If d.exists(x) Then

  23.       t = d(x)

  24.         t = Left(t, Len(t) - 1)

  25.        If InStr(t, ",") Then

  26.            aa = Split(t, ",")

  27.            For j = 0 To UBound(aa)

  28.                Cells(i, 9 + j) = Arr(aa(j), 2)

  29.            Next
  30.       Else

  31.            Cells(i, 9) = Arr(t, 2)

  32.        End If

  33.     End If

  34. Next
  35. '主要想設置"H"欄數量由大至小,這邊以錄製巨集使用
  36. ActiveWorkbook.Worksheets("量大未排機").AutoFilter.Sort.SortFields.Clear
  37.     ActiveWorkbook.Worksheets("量大未排機").AutoFilter.Sort.SortFields.Add Key:=Range( _
  38.         "H1:H500"), SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:= _
  39.         xlSortNormal
  40.     With ActiveWorkbook.Worksheets("量大未排機").AutoFilter.Sort
  41.         .Header = xlYes
  42.         .MatchCase = False
  43.         .Orientation = xlTopToBottom
  44.         .SortMethod = xlPinYin
  45.         .Apply
  46.     End With
  47. End Sub
複製代碼

TOP

回復 120# c_c_lai


    這問題佔了好多的樓層  
    搞到我連我回復的帖都看不到了XD
    C大有其他可以回復的地方嗎~
    我們處理完丟結果上來好像比較不佔空間...

TOP

回復 118# starbox520
試試看!
  1. Private Sub CommandButton2_Click()
  2.     Dim Arr As Variant, Brr As Variant, aa As Variant, i&, j&, x$, Myr&
  3.     Dim d As Object, t As Variant

  4.     Set d = CreateObject("Scripting.Dictionary")
  5.    
  6.    
  7.     '  比對 "TR排機&產出" 灰色欄位 "E" (Customer)、 "F" (Package)、 "G" (Bodysize)、 "H" (L/C) 比對
  8.     '  "量大未排機" 找到一樣的, 秀上 "TR排機&產出" 的 "B" 欄 (機台編號) 同一列的 "機台編號"。
  9.     With Sheets("TR排機&產出")
  10.         Arr = .[A1].CurrentRegion.Value
  11.    
  12.         For i = 4 To (UBound(Arr) - 3) Step 5
  13.             If Not IsError(Arr(i, 5)) Then   '& "|" & Arr(i, 6) & "|" & Arr(i, 7) & "|" & Arr(i, 8)
  14.                  x = Arr(i, 5) & "|" & Arr(i, 6) & "|" & Arr(i, 7) & "|" & Arr(i, 8)
  15.                  d(x) = IIf(IsEmpty(d(x)), CStr(i), d(x) & "," & CStr(i))
  16.             End If
  17.         Next
  18.     End With

  19.     With Sheets("量大未排機")
  20.         Brr = .[A1].CurrentRegion
  21.         
  22.         For i = 2 To UBound(Brr)
  23.             x = Brr(i, 1) & "|" & Brr(i, 2) & "|" & Brr(i, 3) & "|" & Brr(i, 4)
  24.             
  25.             If d.exists(x) Then
  26.                 t = d(x)
  27.                
  28.                 If InStr(t, ",") Then
  29.                     aa = Split(t, ",")
  30.                     
  31.                     For j = 0 To UBound(aa)
  32.                         .Cells(i, 9 + j) = Arr(aa(j), 2)
  33.                     Next
  34.                 Else
  35.                     .Cells(i, 9) = Arr(t, 2)
  36.                 End If
  37.             End If
  38.         Next
  39.         
  40.         '  主要想設置 "H" (數量) 欄 數量由大至小,這邊以錄製巨集使用
  41.         .AutoFilter.Sort.SortFields.Clear
  42.         .AutoFilter.Sort.SortFields.Add Key:=Range( _
  43.                 "H1:H500"), SortOn:=xlSortOnValues, Order:=xlDescending, DataOption:= _
  44.                 xlSortNormal
  45.         
  46.         With .AutoFilter.Sort
  47.             .Header = xlYes
  48.             .MatchCase = False
  49.             .Orientation = xlTopToBottom
  50.             .SortMethod = xlPinYin
  51.             .Apply
  52.         End With
  53.     End With
  54. End Sub
複製代碼

TOP

回復 122# starbox520

TOP

回復 125# c_c_lai


    我剛剛有測試過  
    目前是不會出事XD
    不知道狂點後會不會出事哈哈
    C大修的是什麼概念~

TOP

回復 126# starbox520
盡量 RUN 吧!
會出錯才怪!

TOP

本帖最後由 c_c_lai 於 2016-12-24 20:58 編輯

回復 126# starbox520
在每次按鈕後,順手清除上一次的紀錄,
增加一行 "清除舊有資料" 語法,
以免內容會留下舊有內容產生困擾。
  1.     With Sheets("量大未排機")
  2.         Brr = .[A1].CurrentRegion
  3.         
  4.         .Range("I2:L" & UBound(Brr)) = ""
  5.         For i = 2 To UBound(Brr)
  6.             x = Brr(i, 1) & "|" & Brr(i, 2) & "|" & Brr(i, 3) & "|" & Brr(i, 4)
複製代碼
或是
  1.     With Sheets("量大未排機")
  2.         Brr = .[A1].CurrentRegion
  3.         
  4.         '  .Range("I2:L" & UBound(Brr)) = ""
  5.         .Range("I2:L" & UBound(Brr)).ClearContents
  6.         For i = 2 To UBound(Brr)
複製代碼
接下來, 還有未回答的問題嗎?

TOP

回復 128# c_c_lai
   剩這串哈哈~~~

    我在前置作業有先處理WIP的資料 1.S欄篩出LS1T|LS1N|TR|BK|VQ 字串,其餘的不要
                                                                 2.將J欄的"G"R欄的"R"篩出來,其餘的不要
                                                                 3.'N欄的時間,以當前系統時間 + 4HRS 內 篩出來,空白無時間資料的篩出來,其餘的不要(其餘的指不在這4HRS以內的資料)
                                                                 4."U"欄急貨單號,有任何值,在"I"欄Schedule加上*號
                                                                  之後再寫到Sheet1
       這邊有一個問題是,我的用法也會更改到WIP上的資料,*號部分
       但問題在使用者,如果手殘一直點的話,這個星號會無止進的增加**********會變成一大堆...
       然後我發現我篩完後貼去Sheet1的部分,有的時候會殘留之前的資料
       ->WIP的資料每天會做更新,我試過好像要把Sheet1的資料整個刪除掉在去執行,比較不會出問題...
           這邊我是在"TR排機&產出" 做一個WIP更新的按鈕,之前有想過把這個執行也一同放入 Private Sub Worksheet_SelectionChange(ByVal Target As Range)
         但是跑起來會很久,而且有時候顯示的資料會錯誤,因此最後才用了這個辦法...這部分有更好的作法嗎~

      配上C大之前幫忙修改的,ListBox1 & ListBox2 皆會使用到工作表2跟Shee1
      Sub ArrangeMent() 是從WIP整理過後的資料 (Sheet1)計算出來的
      就是"工作表2"
   
       寫到工作表2的部分,我把執行放到  Private Sub Worksheet_SelectionChange(ByVal Target As Range)
       目前還沒看到錯誤,不知道放在這邊日後會不會有Bug

TOP

本帖最後由 c_c_lai 於 2016-12-25 05:37 編輯

回復 129# starbox520
這串好像是聖經,仔細研究後有疑問再問妳,
今天一整天在 Y17 有方圓舉辦的土風舞聯歡,
我老人家要出門去透透氣了!

TOP

        靜思自在 : 每天無所事事,是人生的消費者,積極、有用才是人生的創造者。
返回列表 上一主題