Anzeige
Anzeige
HERBERS
Excel-Forum (Archiv)
20+ Jahre Excel-Kompetenz: Von Anwendern, für Anwender
Inhaltsverzeichnis

Zellfarbe einer bedingten formatierung ermitteln

Forumthread: Zellfarbe einer bedingten formatierung ermitteln

Zellfarbe einer bedingten formatierung ermitteln
21.11.2005 07:22:12
Thomas
Hi
Ich habe Zellen mit einer bestimmten Farbe formatiert. Abhängig von verschiedenen Faktoren werden die Zellen in einer anderen Farbe dargestellt. Wie kann ich in VBA diese Farbe ermitteln? Mit interior.colorindex erhalte ich ja nur die ursprüngliche Formatierung.
Gruß Thomas
Anzeige

4
Beiträge zum Forumthread
Beiträge zu diesem Forumthread

Betreff
Datum
Anwender
Anzeige
AW: Zellfarbe einer bedingten formatierung ermitte
21.11.2005 07:53:05
Matthias G
Hallo Thomas,
z.B. bei 2 Bedingungen:
Debug.Print ActiveCell.FormatConditions(1).Interior.ColorIndex
Debug.Print ActiveCell.FormatConditions(2).Interior.ColorIndex
Gruß Matthias
AW: Zellfarbe einer bedingten formatierung ermitte
21.11.2005 08:22:52
Thomas
Hi Matthias
Das hab ich inzwischen versucht, funktioniert aber nicht. Ich kriege immer einen Laufzeitfehler in der If-Then-Zeile.
Laufzeitfehler 1004
Die Colorindex-Eigenschaft des Interior-Objektes kann nicht zugeordnet werden.
For i = 0 To 189
With ThisWorkbook.Worksheets("1Halbjahr").Cells(5, 5 + i)
If .FormatConditions(1).Interior.ColorIndex = 4 Then
.Value = ""
Else
.Value = "T"
End If
End With
Next i
Gruß Thomas
Anzeige
AW: Zellfarbe einer bedingten formatierung ermitte
21.11.2005 09:26:53
HermannZ
Hallo Thomas;
schaue einmal hier; http://www.cpearson.com/excel/CFColors.htm
dann wirst du sehen das das nicht so einfach ist.
Gruß hermann
AW: Zellfarbe einer bedingten formatierung ermitteln
21.11.2005 09:36:30
Hajo_Zi
Hallo Thomas,
wie de anderen schon geschrieben habe ist es nich so einfach die Farbe der bedingten Formatierung auszulesen. Einfacher ist es da schon die Bedingung für die bedingte Formatierung nachzubauen.
Einen Code zum auslesen der Farbe findest Du auf meiner HP Seite fremde Dateien.
Link zur Datei


Anzeige
;

Forumthreads zu verwandten Themen

Anzeige
Anzeige
Anzeige
Entdecke relevante Threads

Schau dir verwandte Threads basierend auf dem aktuellen Thema an

Alle relevanten Threads mit Inhaltsvorschau entdecken
Anzeige

Infobox / Tutorial

Zellfarbe einer bedingten Formatierung ermitteln


Schritt-für-Schritt-Anleitung

Um die Zellfarbe einer bedingten Formatierung in Excel mit VBA auszulesen, kannst du die folgenden Schritte befolgen:

  1. Öffne den Visual Basic for Applications (VBA) Editor: Drücke ALT + F11 in Excel.

  2. Füge ein neues Modul hinzu: Klicke mit der rechten Maustaste auf "VBAProject (DeineDatei.xlsx)" und wähle "Einfügen" > "Modul".

  3. Kopiere den folgenden VBA-Code in das Modul:

    Sub ZellfarbeAuslesen()
       Dim i As Integer
       For i = 0 To 189
           With ThisWorkbook.Worksheets("1Halbjahr").Cells(5, 5 + i)
               If .FormatConditions.Count > 0 Then
                   Debug.Print .FormatConditions(1).Interior.ColorIndex
               Else
                   Debug.Print "Keine bedingte Formatierung"
               End If
           End With
       Next i
    End Sub
  4. Führe das Skript aus: Stelle sicher, dass das Arbeitsblatt "1Halbjahr" die Zellen mit der bedingten Formatierung enthält, und starte das Skript.

Mit diesen Schritten kannst du die Farbe der bedingten Formatierung auslesen.


Häufige Fehler und Lösungen

  • Laufzeitfehler 1004: Dieser Fehler tritt auf, wenn du versuchst, auf eine nicht vorhandene bedingte Formatierung zuzugreifen. Überprüfe, ob die Zelle tatsächlich eine bedingte Formatierung hat, bevor du auf .FormatConditions(1) zugreifst.
  • Falscher ColorIndex: Wenn du den falschen ColorIndex erhältst, stelle sicher, dass die Bedingung korrekt definiert ist. Du kannst auch die ColorIndex-Werte in der Formatierungsregel überprüfen.

Alternative Methoden

Falls du keine VBA-Lösungen verwenden möchtest, kannst du die Bedingungen der bedingten Formatierung direkt nachbauen. Hierbei kannst du die bestehenden Regeln in Excel nutzen, um die gewünschte Farbe zu erkennen.

  1. Gehe zu "Start" > "Bedingte Formatierung" > "Regeln verwalten".
  2. Überprüfe die bestehenden Regeln und passe sie an, um die gewünschte Zellfarbe zu erzielen.

Praktische Beispiele

Ein einfaches Beispiel, um die Farbe einer bedingten Formatierung auszulesen:

Angenommen, du hast in Excel eine Zelle, die rot gefärbt ist, wenn der Wert kleiner als 50 ist. Mit dem oben genannten VBA-Skript kannst du die ColorIndex dieser Zelle auslesen und entsprechend verarbeiten.

If .FormatConditions(1).Interior.ColorIndex = 3 Then
    ' Aktion für rote Zelle
End If

Tipps für Profis

  • Nutze Debug.Print, um die Werte der ColorIndex im Direktfenster anzuzeigen. So kannst du schnell erkennen, welche Farben in deinem Arbeitsblatt verwendet werden.
  • Experimentiere mit verschiedenen ColorIndex-Werten, um ein besseres Verständnis für die Farbe der bedingten Formatierung in Excel zu bekommen.
  • Berücksichtige, dass es in Excel keine native Funktion gibt, um die Farbe einer bedingten Formatierung direkt in einer Formel abzufragen. VBA ist hier die beste Wahl.

FAQ: Häufige Fragen

1. Wie kann ich die Farbe einer Zelle ohne VBA auslesen?
Es gibt keine native Excel-Funktion, um die Farbe einer bedingten Formatierung auszulesen. VBA ist die beste Option.

2. Was sind die ColorIndex-Werte in Excel?
ColorIndex ist ein Wert, der einer bestimmten Farbe zugeordnet ist. In Excel sind die Werte von 1 bis 56 vordefiniert. Du kannst den ColorIndex einer Zelle mit .Interior.ColorIndex abrufen.

3. Kann ich die bedingte Formatierung in Excel ohne Code ändern?
Ja, du kannst die Bedingungen direkt in der Benutzeroberfläche von Excel unter "Bedingte Formatierung" ändern. Schauen Sie sich die bestehenden Regeln an und passe sie nach Bedarf an.

Beliebteste Forumthreads (12 Monate)

Anzeige
Anzeige
Entdecke mehr
Finde genau, was du suchst

Die erweiterte Suchfunktion hilft dir, gezielt die besten Antworten zu finden

Suche nach den besten Antworten
Unsere beliebtesten Threads

Entdecke unsere meistgeklickten Beiträge in der Google Suche

Top 100 Threads jetzt ansehen
Anzeige