Farbe per Opptionbutton wählen
#1
Guten Morgen Excel Fans,

Ich komm am Montag Morgen gleich mal zur Sache.

Ich habe eine Excel Tabelle in der viele Daten stehen. Diese Daten werden in einer UserForm ausgelesen. Name und Vorname in
einer Listbox eingelesen und sortiert nach Nachname.
Bei klick auf einen Nachname werden wir die Personenbezogenen Daten angezeigt.
Da es sich um eine Tabelle handelt in der Untersuchungsdaten gespeichert werden laufen diese Daten auch ab. Jede TextBox ( 20 Stück ) füllt sich mit den Daten aus der Tabelle die zum Nachnamen passen.

Zum Problem:

Ich plane die nächsten Untersuchungstermin und möchte in die TextBox "nächster_Termin" per OptionButton die Hintergrundfarbe der TextBox ändern. Rot für Nächster Termin nötig, Gelb für Geplant und Grün für alle ok. Es reicht das nur die TextBox "nächster_Termin" die Farbe ändern die dazugehörige Zelle ist egal.

Code:
Private Sub checkbox_G20_Change()

End Sub
Private Sub checkbox_G20_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G24_Change()

End Sub
Private Sub checkbox_G24_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G25_Change()

End Sub
Private Sub checkbox_G25_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G26_2_Change()

End Sub
Private Sub checkbox_G26_2_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G26_Change()

End Sub
Private Sub checkbox_G26_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G29_Change()

End Sub
Private Sub checkbox_G29_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G31_Change()

End Sub
Private Sub checkbox_G31_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G33_Change()

End Sub
Private Sub checkbox_G33_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G37_Change()

End Sub
Private Sub checkbox_G37_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_G41_Change()

End Sub
Private Sub checkbox_G41_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------
Private Sub checkbox_txtG46_Change()

End Sub
Private Sub checkbox_G46_KeyPress(ByVal KeyAscii As MSForms.ReturnInteger)
    If Chr(KeyAscii) Like "[ü]" = False Then KeyAscii = 0
End Sub
----------------------------------------------------------------------------------------------

'Neuer Eintrag Schaltfläche Ereignisroutine
Private Sub Neuer_EintragButton_Click()
  Dim lZeile As Long
    'Wenn der Benutzer einen neuen Eintrag erzeugen möchte,
    'erstellen wir einen neuen Eintrag in der ListBox und markieren
    'diesen, damit der Benutzer die Daten eintragen kann
   
    lZeile = 7 'Start in Zeile 2, Zeile 1 sind ja die überschriftrn
    'Schleife solange etwas in der ersten Spalte in Tabelle 1 drin steht
    Do While Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) <> ""
        lZeile = lZeile + 1 'Nächste Zeile bearbeiten
    Loop
     
     
 
     
     'Nach Durchlauf dieser Schleife steht lZeile in der ersten leeren Zeile von Tabelle1
    'Neuen Eintrag in die Tabelle1 schreiben, Spalte ID muss gefüllt sein, damit
    'unsere Routinen die Zeile wiederfinden!
    Tabelle1.Cells(lZeile, 2) = CStr("Neuer Eintrag Zeile" & lZeile)
   
    'Und neuen Eintrag in die UserForm eintragen
    ListBox1.AddItem CStr("Neuer Eintrag Zeile" & lZeile)
   
    'Den neuen Eintrag markieren mit Hilfe des ListIndexes
    ListBox1.ListIndex = ListBox1.ListCount - 1
    'Durch das Click Ereignis der ListBox werden die Daten automatisch geladen

End Sub
----------------------------------------------------------------------------------------------
'Löschen Schaltfläche Ereignisroutine
Private Sub löschen_Button_Click()
  Dim lZeile As Long
 
    'Wenn kein Datensatz in der ListBox markiert wurde, wird die Routine beendet
    If ListBox1.ListIndex = -1 Then Exit Sub
 
    'Zum Löschen benötigen wir die Zeilennummer des ausgewählten Datensatzes
    lZeile = 7 'Start in Zeile 2, Zeile 1 sind ja die Überschriften
    'Schleife solange etwas in der ersten Spalte in Tabelle 1 drin steht
    Do While Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) <> ""
   
        'Datensatz ID Spalte mit selektiertem Eintrag der ListBox vergleichen
        If ListBox1.Text = Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) Then
            
           
            
             'Eintrag gefunden, die ganze Zeile wird nun gelöscht
            Tabelle1.Rows(CStr(lZeile & ":" & lZeile)).Delete
           
            'Die ListBox muss nun neu geladen werden!
            Call UserForm_Initialize
            If ListBox1.ListCount > 0 Then ListBox1.ListIndex = 0
           
            Exit Do 'Vorzeitiges Ende, da der Datensatz schon gefunden ist
           
        End If
   
        lZeile = lZeile + 1 'Nächste Zeile bearbeiten
    Loop

End Sub
----------------------------------------------------------------------------------------------
'Speichern Schaltfläche Ereignisroutine
Private Sub Speicher_Button_Click()
  Dim lZeile As Long
 
    'Wenn kein Datensatz in der ListBox markiert wurde, wird die Routine beendet
    If ListBox1.ListIndex = -1 Then Exit Sub
   
    'Wir müssen prüfen, ob die ID Spalte auch gefüllt ist!!
    If Trim(CStr(txt_Nachname.Text)) = "" Then
        'Meldung ausgeben
        MsgBox "Sie müssen mindestens einen Namen eingeben!", vbCritical + vbOKOnly, "FEHLER!"
        'Abbrechen der Speicherroutine
        Exit Sub
    End If
    'Ausbauoption: Prüfen, ob die ID in Tabelle1 Spalte 1 schon vorhanden ist!
   
    'Zum Speichern benötigen wir die Zeilennummer des ausgewählten Datensatzes
    lZeile = 7 'Start in Zeile 7, Zeile 6 sind ja die Überschriften
    'Schleife solange etwas in der zweiten Spalte in Tabelle 1 drin steht
    Do While Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) <> ""
    
    
         'Datensatz ID Spalte mit selektiertem Eintrag der ListBox vergleichen
        If ListBox1.Text = Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) Then
           
            'Eintrag gefunden, TextBoxen in die Zellen schreiben
            Tabelle1.Cells(lZeile, 1).Value = LaufendeNummer.Text
            Tabelle1.Cells(lZeile, 2).Value = Trim(CStr(txt_Nachname.Text))
            Tabelle1.Cells(lZeile, 3).Value = Trim(CStr(txt_Vorname.Text))
            Tabelle1.Cells(lZeile, 4).Value = txt_DG.Text
            Tabelle1.Cells(lZeile, 5).Value = txt_TE.Text
            Tabelle1.Cells(lZeile, 6).Value = txt_PK.Text
            Tabelle1.Cells(lZeile, 7).Value = txtstatus.Text
            Tabelle1.Cells(lZeile, 8).Value = txtStatusUnterlagen.Text
            Tabelle1.Cells(lZeile, 9).Value = nächster_termin.Text
            FillMyDateCells lZeile, 10, Me.txtG20
            Tabelle1.Cells(lZeile, 11).Value = checkbox_G20.Text
            FillMyDateCells lZeile, 12, Me.txtg24
            Tabelle1.Cells(lZeile, 13).Value = checkbox_G24.Text
            FillMyDateCells lZeile, 14, Me.txtG25
            Tabelle1.Cells(lZeile, 15).Value = checkbox_G25.Text
            FillMyDateCells lZeile, 16, Me.txtg26
            Tabelle1.Cells(lZeile, 17).Value = checkbox_G26.Text
            FillMyDateCells lZeile, 18, Me.txtG26_2
            Tabelle1.Cells(lZeile, 19).Value = checkbox_G26_2.Text
            FillMyDateCells lZeile, 20, Me.txtG29
            Tabelle1.Cells(lZeile, 21).Value = checkbox_G29.Text
            FillMyDateCells lZeile, 22, Me.txtG31
            Tabelle1.Cells(lZeile, 23).Value = checkbox_G31.Text
            FillMyDateCells lZeile, 24, Me.txtG33
            Tabelle1.Cells(lZeile, 25).Value = checkbox_G33.Text
            FillMyDateCells lZeile, 26, Me.txtG37
            Tabelle1.Cells(lZeile, 27).Value = checkbox_G37.Text
            FillMyDateCells lZeile, 28, Me.txtG41
            Tabelle1.Cells(lZeile, 29).Value = checkbox_G41.Text
            FillMyDateCells lZeile, 30, Me.txtG46
            Tabelle1.Cells(lZeile, 31).Value = checkbox_G46.Text
                       
            'Die ListBox muss nun neu geladen werden
            'allerdings nur, wenn sich der txt_Nachname (ID) geändert hat
            If ListBox1.Text <> Trim(CStr(txt_Nachname.Text)) Then
                Call UserForm_Initialize
                If ListBox1.ListCount > 0 Then ListBox1.ListIndex = 0
            End If
           
            Exit Do 'Vorzeitiges Ende, da der Datensatz schon gefunden ist
           
        End If
   
        lZeile = lZeile + 1 'Nächste Zeile bearbeiten


       
    Loop
  'Dein Code

End Sub
----------------------------------------------------------------------------------------------
'Beenden Schaltfläche Ereignisroutine
Private Sub schliessen_Button_Click()
    Unload Me
End Sub
----------------------------------------------------------------------------------------------
Private Sub txtG46_AfterUpdate()
If IsDate(txtG46) Then txtG46 = Format(txtG46, "MMM.YY")
End Sub

Private Sub txtG46_Exit(ByVal Cancel As MSForms.ReturnBoolean)
If Not IsDate(txtG46) Then
txtG46 = ""
Cancel = True
End If
End Sub
----------------------------------------------------------------------------------------------

'Klick auf die ListBox Ereignisroutine
Private Sub ListBox1_Click()
  Dim lZeile As Long
    'Wenn der Benutzer einen Namen anklickt, suchen wir
    'diesen in der Tabelle1 heraus und tragen die Daten
    'in die TextBoxen ein.
   
    'Wir löschen standardmäßig alle bisherigen TextBoxen-Inhalte
    LaufendeNummer = ""
    txt_Nachname = ""
    txt_Vorname = ""
    txt_DG = ""
    txt_TE = ""
    txt_PK = ""
    txtstatus = ""
    txtStatusUnterlagen = ""
    nächster_termin = ""
    Me.txtG20 = vbNullString
    checkbox_G20 = ""
    Me.txtg24 = vbNullString
    checkbox_G24 = ""
    Me.txtG25 = vbNullString
    checkbox_G25 = ""
    Me.txtg26 = vbNullString
    checkbox_G26 = ""
    Me.txtG26_2 = vbNullString
    checkbox_G26_2 = ""
    Me.txtG29 = vbNullString
    checkbox_G29 = ""
    Me.txtG31 = vbNullString
    checkbox_G31 = ""
    Me.txtG33 = vbNullString
    checkbox_G33 = ""
    Me.txtG37 = vbNullString
    checkbox_G37 = ""
    Me.txtG41 = vbNullString
    checkbox_G41 = ""
    Me.txtG46 = vbNullString
    checkbox_G46 = ""
   
    'Nur wenn ein Eintrag selektiert/markiert ist
    If ListBox1.ListIndex >= 0 Then
   
        lZeile = 7 'Start in Zeile 7, Zeile 6 sind ja die Überschriften
        'Schleife solange etwas in der zweiten Spalte in Tabelle 1 drin steht
        Do While Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) <> ""
         
       
            'Wenn wir den Namen aus der ListBox1 in der Tabelle1 Spalte 2
            'gefunden haben, übertragen wir die anderen Spalteninhalte
            'in die TextBoxen!
            If ListBox1.Text = Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) Then
             
           
                'TextBoxen füllen
                LaufendeNummer = Tabelle1.Cells(lZeile, 1).Value
                txt_Nachname = ListBox1.List(ListBox1.ListIndex, 0)
                txt_Vorname = ListBox1.List(ListBox1.ListIndex, 1)
                txt_DG = Tabelle1.Cells(lZeile, 4).Value
                txt_TE = Tabelle1.Cells(lZeile, 5).Value
                txt_PK = Tabelle1.Cells(lZeile, 6).Value
                txtstatus = Tabelle1.Cells(lZeile, 7).Value
                txtStatusUnterlagen = Tabelle1.Cells(lZeile, 8).Value
                nächster_termin = Tabelle1.Cells(lZeile, 9).Value
                FillAndFormatDate2DateText Me.txtG20, Tabelle1.Cells(lZeile, 10).Value
                checkbox_G20 = Tabelle1.Cells(lZeile, 11).Value
                FillAndFormatDate2DateText Me.txtg24, Tabelle1.Cells(lZeile, 12).Value
                checkbox_G24 = Tabelle1.Cells(lZeile, 13).Value
                FillAndFormatDate2DateText Me.txtG25, Tabelle1.Cells(lZeile, 14).Value
                checkbox_G25 = Tabelle1.Cells(lZeile, 15).Value
                FillAndFormatDate2DateText Me.txtg26, Tabelle1.Cells(lZeile, 16).Value
                checkbox_G26 = Tabelle1.Cells(lZeile, 17).Value
                FillAndFormatDate2DateText Me.txtG26_2, Tabelle1.Cells(lZeile, 18).Value
                checkbox_G26_2 = Tabelle1.Cells(lZeile, 19).Value
                FillAndFormatDate2DateText Me.txtG29, Tabelle1.Cells(lZeile, 20).Value
                checkbox_G29 = Tabelle1.Cells(lZeile, 21).Value
                FillAndFormatDate2DateText Me.txtG31, Tabelle1.Cells(lZeile, 22).Value
                checkbox_G31 = Tabelle1.Cells(lZeile, 23).Value
                FillAndFormatDate2DateText Me.txtG33, Tabelle1.Cells(lZeile, 24).Value
                checkbox_G33 = Tabelle1.Cells(lZeile, 25).Value
                FillAndFormatDate2DateText Me.txtG37, Tabelle1.Cells(lZeile, 26).Value
                checkbox_G37 = Tabelle1.Cells(lZeile, 27).Value
                FillAndFormatDate2DateText Me.txtG41, Tabelle1.Cells(lZeile, 28).Value
                checkbox_G41 = Tabelle1.Cells(lZeile, 29).Value
                FillAndFormatDate2DateText Me.txtG46, Tabelle1.Cells(lZeile, 30).Value
                checkbox_G46 = Tabelle1.Cells(lZeile, 31).Value
           
                Exit Do 'Vorzeitiges Ende, da der Datensatz schon gefunden ist
           
            End If
       
            lZeile = lZeile + 1 'Nächste Zeile bearbeiten
       
        Loop
       
    End If
   
End Sub
----------------------------------------------------------------------------------------------
Private Sub FillAndFormatDate2DateText(ByVal ctl As Control, ByVal myText As String)
   If IsDate(myText) Then
       ctl = Format(myText, "MMM YYYY")
   Else
       ctl = vbNullString
   End If
End Sub
----------------------------------------------------------------------------------------------

Private Sub txtG24_AfterUpdate()
If IsDate(txtg24) Then txtg24 = Format(txtg24, "MMM YYYY")
End Sub

Private Sub txtG24_Change()
 
End Sub
----------------------------------------------------------------------------------------------
Private Sub txtG24_Exit(ByVal Cancel As MSForms.ReturnBoolean)
If Not IsDate(txtg24) Then
txtg24 = ""
Cancel = True
End If
End Sub
----------------------------------------------------------------------------------------------

Private Sub UserForm_Activate()
    'Wenn die Eingabemaske angezeigt wird, markieren wir den ersten Namen
    'jedoch nur, wenn auch Einträge in der Liste stehen
    If ListBox1.ListCount > 0 Then ListBox1.ListIndex = 0
       
   
End Sub
----------------------------------------------------------------------------------------------
'Startroutine, wird ausgeführt bevor die Eingabemaske angezeigt wird
Private Sub UserForm_Initialize()
   
  Dim lZeile As Long
 
    'Alle TextBoxen leer machen
    LaufendeNummer = ""
    txt_Nachname = ""
    txt_Vorname = ""
    txt_DG = ""
    txt_TE = ""
    txt_PK = ""
    txtstatus = ""
    txtStatusUnterlagen = ""
    nächster_termin = ""
    Me.txtG20 = vbNullString
    checkbox_G20 = ""
    Me.txtg24 = vbNullString
    checkbox_G24 = ""
    Me.txtG25 = vbNullString
    checkbox_G25 = ""
    Me.txtg26 = vbNullString
    checkbox_G26 = ""
    Me.txtG26_2 = vbNullString
    checkbox_G26_2 = ""
    Me.txtG29 = vbNullString
    checkbox_G29 = ""
    Me.txtG31 = vbNullString
    checkbox_G31 = ""
    Me.txtG33 = vbNullString
    checkbox_G33 = ""
    Me.txtG37 = vbNullString
    checkbox_G37 = ""
    Me.txtG41 = vbNullString
    checkbox_G41 = ""
    Me.txtG46 = vbNullString
    checkbox_G46 = ""
   
 
    'In dieser Routine laden wir alle vorhandenen
    'Einträge in die ListBox1
    ListBox1.Clear 'Zuerst einmal die Liste leeren
   
    lZeile = 7 'Start in Zeile 7, Zeile 6 sind ja die Überschriften
    'Schleife solange etwas in der zweiten Spalte in Tabelle 1 drin steht
    Do While Trim(CStr(Tabelle1.Cells(lZeile, 2).Value)) <> ""

 
       
        'Aktuelle Zeile in die ListBox eintragen
        ListBox1.AddItem
           ListBox1.List(ListBox1.ListCount - 1, 0) = Cells(lZeile, 2).Text
           ListBox1.List(ListBox1.ListCount - 1, 1) = Cells(lZeile, 3).Text
           
        lZeile = lZeile + 1 'Nächste Zeile bearbeiten
       
    Loop

     
End Sub

Private Sub FillMyDateCells(ByVal iRow As Long, ByVal ICol As Long, ByVal dateValue As String)
   With Tabelle1
       If IsDate(dateValue) Then
           .Cells(iRow, ICol) = CDate(dateValue)
       Else
           .Cells(iRow, ICol) = vbNullString
       End If
   End With
End Sub
Top
#2
Hallöchen,

ich habe jetzt in Deinem Code keine Optionbuttons gefunden. Im Prinzip geht das so:

Private Sub OptionButton1_Click()
Me.TextBox1.BackColor = vbRed
End Sub

Private Sub OptionButton2_Click()
Me.TextBox1.BackColor = vbGreen
End Sub

Die OptionButtons sollten wegen der Abhängigkeiten dann in einem Frame stehen.
.      \\\|///      Hoffe, geholfen zu haben.
       ( ô ô )      Grüße, André aus G in T  
  ooO-(_)-Ooo    (Excel 97-2019+365)
Top


Gehe zu:


Benutzer, die gerade dieses Thema anschauen: 1 Gast/Gäste