Microsoft Excel

Herbers Excel/VBA-Archiv

Dropdownliste ausgew. gültige Werte aktualisieren

Betrifft: Dropdownliste ausgew. gültige Werte aktualisieren von: Flo
Geschrieben am: 16.08.2008 16:24:58

Hallo allerseits!

Ich habe ein Problem mit der Aktualisierung von bereits ausgewählten gültigen Werten in einer Dorpdownliste. Die gütligen Werte der Dropdownliste werden per Namensdefinition aus einem anderen Excelblatt gefüllt. Nun kommt es öfter mal vor, dass sich die Gültigen Werte im separaten Excelblatt ändern.

Mit der aktuellen Lösung taucht jetzt das Problem auf, dass sich die Änderungen der Werte im separaten Exelblatt nicht auf die bereits ausgewählten Werte in den Dropdwownliste übertragen.

Beispiel:
Dropdownliste ausgewählt: Auto
Wertebreich Änderung im separaten Blatt: von Auto auf PKW

jetzt steht in der Dropdownliste leider immer noch der Wert "Auto" und nicht der an dieser Stelle ersetztende neue gültige Wert "PKW".

Gibt es hierfür eine Lösung, evtl. mittels VBA?

Vielen Dank!

Gruß

Flo

  

Betrifft: AW: Dropdownliste ausgew. gültige Werte aktualisieren von: {Boris}
Geschrieben am: 16.08.2008 17:44:25

Hi Flo,

ein mittels Dropdown ausgewählter Wert ist nunmal fix in der Zelle verankert.
Du könntest mit einem Ereignismakro (Change-Event in Kombination mit Selection-Change) bei Änderung der Quelldaten die alten Werte prüfen und mit den neuen überschreiben.

Alles in das Klassenmodul des Tabellenblattes mit den Quelldaten:

Option Explicit
Public oldValue As Variant

Private Sub Worksheet_Change(ByVal Target As Range)
With Tabelle1.Range("A:A")
  .Replace oldValue, Target
End With
End Sub

Private Sub Worksheet_SelectionChange(ByVal Target As Range)
oldValue = ActiveCell
End Sub



Den Codenamen der Tabelle, in der die Änderungen erfolgen sollen (hier: Tabelle1) sowie den Bereich (hier: Spalte A) musst Du natürlich anpassen.

Nur das Prinzip - alles noch ohne Fehlerbehandlung.

Grüße Boris


 

Beiträge aus den Excel-Beispielen zum Thema "Dropdownliste ausgew. gültige Werte aktualisieren"