返回列表 上一主題 發帖

[發問] excel VBA 自動更新篩選問題

回復 9# Andy2483
Dear Andy2483,
剛剛測試使用OK,感恩囉。
請問一下,若項目超過5個以上的話,
是否修訂下列語法即可


   Dim Qx$, Af&, Sh$, S1$, S2$, S3$, S4$, S5$,  S6$,  S7$, i&
   Af = 32
   Sh = ""
   S1 = ""
   S2 = ""
   S3 = ""
   S4 = ""
   S5 = ""
  S6 = ""
   S7 = ""
Just do it.

TOP

回復 10# jsc0518


ElseIf InStr(Sh, Cells(i, "AF")) <> 0 Then
     GoTo 999
如果儲存格Cells(i, "AF")是顯示的且在隱藏的儲存格裡有
就跳到 999繼續執行

TOP

回復 11# jsc0518


    後面有關係到項目的都要類推EX:
ElseIf S6 = "" And InStr(S1 & S2 & S3 & S4 & S5, Cells(i, "AF")) = 0 Then
   S6 = Cells(i, "AF")
~~~

多試幾次就會了!

TOP

回復 11# jsc0518


    應該可以設計不限制項目數量!
但我不會! 靜待高手指導!

TOP

回復 12# Andy2483
Dear Andy2483,
感謝您的回覆與教導!
Just do it.

TOP

回復 13# Andy2483

了解囉,真的很感謝你的教導歐!
Just do it.

TOP

回復 16# jsc0518


    '研究了3個帖子拼湊出了 不限項目數量的方法
Option Explicit
Private Sub Worksheet_Change(ByVal Target As Range)
With Target
   Dim Af&, Sh$, i&, Arr(), Brr(), K&, Dic As Object
   Set Dic = CreateObject("scripting.dictionary")
   Af = 32
   If .Column = Af And .Row >= 2 And .Count = 1 Then
      If ActiveSheet.FilterMode = True Then
         Arr = Range("AF2:AF" & ActiveSheet.UsedRange.Rows.Count)
         ReDim Brr(1 To UBound(Arr), 1 To 1)
         For i = 1 To UBound(Arr)
            If Rows(i).EntireRow.Hidden = True Then
               If Sh = "" Then
                  Sh = Cells(i, "AF")
                  ElseIf InStr(Sh, Cells(i, "AF")) = 0 Then
                     Sh = Sh & "," & Cells(i, "AF")
               End If
               ElseIf InStr(Sh, Cells(i, "AF")) <> 0 Then
                  GoTo 999
               ElseIf Dic.exists(Arr(i, 1)) Then
                  Dic(Arr(i, 1)) = ""
                  K = K + 1
                  Brr(K, 1) = Arr(i, 1)
            End If
            
999
         Next
         If InStr(Sh, .Value) <> 0 Then
            .Rows(.Count).EntireRow.Hidden = True
            ElseIf K > 0 Then
               Selection.AutoFilter Field:=Af, Criteria1:=Brr, Operator:=xlFilterValues
               ActiveSheet.AutoFilter.ApplyFilter
         End If
      End If
   End If
End With
End Sub
'猜測生產流程是 待料>待生產>生產中>結批  特殊狀況 機台異常or暫停 以下經驗供參考
Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)
With Target
   '在AF欄儲存格以滑鼠左鍵快按兩次>>依照流程 改變流程進度
   If .Column = 32 And .Row >= 2 Then
      If .Value = "待料" Then
         .Value = "待生產"
         ElseIf .Value = "待生產" Then
            .Value = "生產中"
         ElseIf .Value = "生產中" Then
            .Value = "結批"
         ElseIf .Value = "結批" Then
            MsgBox "?"
         ElseIf .Value = "機台異常" Then
            .Value = "生產中"
         ElseIf .Value = "暫停" Then
            .Value = "生產中"
      End If
      Cancel = True
   End If
   '在AG欄儲存格以滑鼠左鍵快按兩次>>改變流程特別狀況(機台異常)
   If .Column = 33 And .Row >= 2 Then
      If .Cells(1, 0) = "生產中" Then
         .Cells(1, 0) = "機台異常"
      End If
      Cancel = True
   End If
   '在AF1儲存格以滑鼠左鍵快按兩次>>解除全部欄位篩選
   If .Address = "$AF$1" Then
      If ActiveSheet.FilterMode = True Then
         ActiveSheet.ShowAllData
      End If
      Cancel = True
   End If
End With
End Sub
Private Sub Worksheet_BeforeRightClick(ByVal Target As Range, Cancel As Boolean)
With Target
   '在AF欄儲存格按滑鼠右鍵>>直接幫在AF欄篩選當格的項目
   'EX: 在沒有篩選的情況下 在AF2儲存格按滑鼠右鍵,如果AF2的文字是 "生產中" 就幫在AF欄篩選 "生產中"
   If .Column = 32 And .Row >= 2 And .Count = 1 Then
      If ActiveSheet.FilterMode = True Then
         ActiveSheet.ShowAllData
      End If
      Selection.AutoFilter Field:=32, Criteria1:=.Value, Operator:=xlFilterValues
      Cancel = True
   End If
   '在AG欄儲存格按滑鼠右鍵>>改變流程特別狀況(暫停)
   If .Column = 33 And .Row >= 2 Then
      If .Cells(1, 0) = "生產中" Then
         .Cells(1, 0) = "暫停"
      End If
      Cancel = True
   End If
End With

參考!
End Sub

TOP

回復 17# Andy2483
Dear Andy2483,
下午好!感謝您的熱心回復歐,我再來測試看看!
Thank you so much. ^^
Just do it.

TOP

本帖最後由 n7822123 於 2021-7-25 21:47 編輯

回復 18# jsc0518

這討論串還活著阿,看了一下,感覺搞複雜摟~~

只要想辦法記錄 "使用者不要的" 選項,再重新設定篩選條件就好了呀~

弄一個給你們參考看看吧,放棄原本手動用第一列篩選的功能,用表單篩選


1.任一欄點選兩下左鍵跳出表單
2.表單會自動抓第2列的 "資料篩選清單",並秀出來給你選擇
3.把"要的"打勾,按確定即可完成篩選 (程式會自動記錄你"不要"的)
4.假設該欄資料沒有ItemA,但是清單有打勾,該欄多了一筆資料ItemA,也不會自動隱藏
5.支援擴充N欄,不限"AF"欄,但是若該欄沒有"資料篩選清單",表單上不會有東西給你勾
6.設定條件可以紀錄到檔案關閉,亦即檔案關閉再開啟,需要重新設定
7.目前只支援1個表格,若要支援多表格,請自行擴充模組"儲存List",取不同模組名稱即可
   Ex:"表2儲存List"、"表3儲存List" ,如此才能記錄不同表格的 篩選條件(不要的)
8.表單範圍大概支援30個選項,再多應該顯示不出來


Error_阿龍.rar (34.21 KB)
程式是依需求寫的,需求表達不清楚
或者沒有上傳附件,愛莫能助

TOP

本帖最後由 singo1232001 於 2021-7-26 00:16 編輯

回復 1# jsc0518


先說明一下
我寫的很心虛
可能會有一堆奇怪bug
就當作參考 玩看看

我認為最有可能出現的bug 在於 更之後的運用
也就是當你把真實資料放入
或者操作一些範例外的資料
可能就會產生未知bug
尤其是 af欄 清除資料 或者 突然新增資料
資料記得要備份 並且 先行實際測試 各種操作 喔

另外裡面有一些累贅的程序 我沒殺掉 比如rd變數
因為我想說 可能會有bug 不敢亂刪 或者之後修改要用到

error v1.zip (27.02 KB)

TOP

        靜思自在 : 太陽光大、父母恩大、君子量大,小人氣大。
返回列表 上一主題