Thema Datum  Von Nutzer Rating
Antwort
30.09.2021 19:01:52 mh
*****
Solved
30.09.2021 20:16:28 xlKing
*****
Solved
01.10.2021 13:56:49 mh
Solved
01.10.2021 14:00:37 mh
Solved
Rot Zellenwert anhand mehrerer Vergleichskriterien
02.10.2021 12:38:36 xlKing
*****
Solved
07.10.2021 12:14:07 mh
Solved

Ansicht des Beitrags:
Von:
xlKing
Datum:
02.10.2021 12:38:36
Views:
269
Rating: Antwort:
 Nein
Thema:
Zellenwert anhand mehrerer Vergleichskriterien

Hallo mh,

dafür brauchst du die Funktion KGRÖSSTE anstelle von MAX. Probiers mal mit diesem Code:

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
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
Sub Filtern()
 
Set r = Range("A1:E6")
crit1 = "Gruppe2"
crit2 = "Name7"
  
Application.ScreenUpdating = False
  
If Not FilterIsActive(r) Then
  r.AutoFilter  'Filter ein
  fseton = True
End If
 
If r.Parent.AutoFilter.FilterMode = True Then
  r.AutoFilter
  r.AutoFilter
End If
 
r.AutoFilter Field:=1, Criteria1:=crit1
r.AutoFilter Field:=2, Criteria1:=crit2
 
imax = Application.Count(r.Columns(3).SpecialCells(xlCellTypeVisible))
For i = 1 To imax
 r.AutoFilter Field:=3
 r.AutoFilter Field:=4
 r.AutoFilter Field:=3, Criteria1:=CStr(CDate(Application.Large(r.Columns(3).SpecialCells(xlCellTypeVisible), i)))
 kmax = Application.Count(r.Columns(4).SpecialCells(xlCellTypeVisible))
 For k = 1 To kmax
   r.AutoFilter Field:=4
   r.AutoFilter Field:=4, Criteria1:=CStr(CDate(Application.Large(r.Columns(4).SpecialCells(xlCellTypeVisible), k)))
   If r.Columns(5).SpecialCells(xlCellTypeVisible).Areas.Count = 1 Then
      Wert = r.Columns(5).SpecialCells(xlCellTypeVisible).Areas(1).Cells(2).Value
   Else
      Wert = r.Columns(5).SpecialCells(xlCellTypeVisible).Areas(2).Cells(1).Value
   End If
   If Wert <> "" And Wert <> 0 And Wert <> "000.000.000" Then gefunden = True
   If gefunden = True Then Exit For
 Next k
 If gefunden = True Then Exit For
Next i
 
Application.ScreenUpdating = True
 
If gefunden = False Then MsgBox "Für die Kriterien " & crit1 & " und " & crit2 & " gibt es keinen gültigen Wert!", vbExclamation Else MsgBox "Wert: " & Wert, vbInformation
 
If fseton Then
r.AutoFilter 'Filter wieder aus
End If
 
End Sub
Function FilterIsActive(ByVal r As Range) As Boolean
On Error Resume Next
FilterIsActive = r.Parent.AutoFilter.Filters.Count > 0
End Function

Gruß Mr. K.


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
30.09.2021 19:01:52 mh
*****
Solved
30.09.2021 20:16:28 xlKing
*****
Solved
01.10.2021 13:56:49 mh
Solved
01.10.2021 14:00:37 mh
Solved
Rot Zellenwert anhand mehrerer Vergleichskriterien
02.10.2021 12:38:36 xlKing
*****
Solved
07.10.2021 12:14:07 mh
Solved