Thema Datum  Von Nutzer Rating
Antwort
11.07.2017 12:41:34 Franzi
NotSolved
11.07.2017 13:04:22 fedjo
NotSolved
11.07.2017 13:20:58 Gast462
NotSolved
11.07.2017 13:31:17 Gast83982
NotSolved
11.07.2017 13:36:19 Gast95222
NotSolved
Blau Filter
11.07.2017 19:08:41 Gast70117
NotSolved

Ansicht des Beitrags:
Von:
Gast70117
Datum:
11.07.2017 19:08:41
Views:
737
Rating: Antwort:
  Ja
Thema:
Filter

Hi Franzi,

so nach deinen Angaben einfach gestrickt (eine Klasse für das Click-Ereignis wäre besser)

in das Modul Tabelle1

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
Option Explicit
 
Private Sub CheckBox1_Click()
    FltrIt ActiveSheet
End Sub
 
Private Sub CheckBox2_Click()
    FltrIt ActiveSheet
End Sub
 
Private Sub CheckBox3_Click()
    FltrIt ActiveSheet
End Sub
 
Private Sub CheckBox4_Click()
    FltrIt ActiveSheet
End Sub
 
Private Sub CheckBox5_Click()
    FltrIt ActiveSheet
End Sub
 
Private Sub CheckBox6_Click()
    FltrIt ActiveSheet
End Sub

 

in ein neues Modul

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
Sub FltrIt(Sh As Excel.Worksheet)
Dim oOle As OLEObject
Dim arr() As Variant, x As Integer, elm As Variant
Dim uRng As Range, Rng As Range, rw As Range, c As Range
 
   With Sh
      For Each oOle In Sh.OLEObjects
         If oOle.progID = "Forms.CheckBox.1" _
         And Not Intersect(.Range("A1:F1"), oOle.TopLeftCell) Is Nothing _
         And oOle.Object.Value = True Then
             
            x = x + 1
            ReDim Preserve arr(1 To x)
            arr(x) = oOle.TopLeftCell.Address(0, 0)
             
         End If
      Next oOle
       
      Set uRng = .UsedRange
      Set Rng = uRng.Offset(2).Resize(uRng.Rows.Count - 2)
      Rng.EntireRow.Hidden = True
       
      For Each rw In Rng.Rows
         On Error GoTo errh
         For Each elm In arr
            Set c = .Range(elm)
            If WorksheetFunction.CountIf(rw, c.Value) Then rw.EntireRow.Hidden = False
         Next elm
         On Error GoTo 0
      Next rw
       
   End With
 
errh:
If Err.Number Then Rng.EntireRow.Hidden = False
 
End Sub

 


Ihre Antwort
  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen
Thema: Name: Email:



  • Bitte beschreiben Sie Ihr Problem möglichst ausführlich. (Wichtige Info z.B.: Office Version, Betriebssystem, Wo genau kommen Sie nicht weiter)
  • Bitte helfen Sie ebenfalls wenn Ihnen geholfen werden konnte und markieren Sie Ihre Anfrage als erledigt (Klick auf Häckchen)
  • Bei Crossposting, entsprechende Links auf andere Forenbeiträge beifügen / nachtragen
  • Codeschnipsel am besten über den Code-Button im Text-Editor einfügen
  • Die Angabe der Emailadresse ist freiwillig und wird nur verwendet, um Sie bei Antworten auf Ihren Beitrag zu benachrichtigen

Thema Datum  Von Nutzer Rating
Antwort
11.07.2017 12:41:34 Franzi
NotSolved
11.07.2017 13:04:22 fedjo
NotSolved
11.07.2017 13:20:58 Gast462
NotSolved
11.07.2017 13:31:17 Gast83982
NotSolved
11.07.2017 13:36:19 Gast95222
NotSolved
Blau Filter
11.07.2017 19:08:41 Gast70117
NotSolved