Das Clever-Excel-Forum.de - Treffen
findet vom 15. - 17. September 2017 in Thüringen / Region Großer Inselsberg statt. Hotelbuchung ab sofort möglich.


VBA Globale Variable in Userform füllen und später auslesen
#1
Hallo

Ich habe wiedermal ein Problem. Nachdem ich mir diverse Forenbeiträge angesehen habe, bin ich zwar ein Stück schlauer, aber es reicht nicht.

Dummerweise habe ich mir vorgenommen ein Userform zu nutzen um 3 Button mit eigener Beschriftung zu bekommen. Nun brauche ich aber das Ergebnis der Auswahl nicht im Userform-Code sondern zentral bei "DieseArbeitsmappe".

Dort habe ich nun schon eine Variable definiert, die ich in Userform füllen will. Dort behält sie auch den Wert, aber zurück im Code nach dem Aufruf kommt 0 oder gar nichts raus.

Code:
Option Explicit
Public Auswahl As Byte
Private Sub Workbook_BeforePrint(Cancel As Boolean)
...
   Else: UserForm1.Show
       MsgBox Auswahl
       Unload UserForm1

Userform:
Code:
Private Sub CommandButton1_Click()
Auswahl = 1
UserForm1.Hide
MsgBox Auswahl
End Sub

Was muss ich anders definieren oder machen, damit ich "Auswahl" oben richtig übergeben bekomme?

Danke
Grüße,

Hardilein
mit Excel 2003
to top
#2
Hallo,

nimm einfach die Tag-Eigenschaft der Userform.

UserForm1:
Code:
Private Sub CommandButton1_Click()
 Me.Tag = "Hallo"
 Me.Hide
End Sub

DieseArbeitsmappe:
Code:
Private Sub Workbook_BeforePrint(Cancel As Boolean)
...
 Else
   UserForm1.Show
   MsgBox UserForm1.Tag
   Unload UserForm1
 End If

Gruß Uwe
to top
#3
Hallo

Danke, klappt.

Das ist genau das, was ich anderswo nicht verstanden habe, wo es aber auch umfangreicher war. "Tag" ist eine festgelegte "Variable" für solchen Fall? "Me" bezieht sich einfach auf die Userform? Falls mehrere parallel aufgehen, ist jede in diesem Moment selber angesprochen?
Grüße,

Hardilein
mit Excel 2003
to top
#4
Hallo,

das steht in der VBA-Hilfe:
Zitat:Tag-Eigenschaft

Speichert zusätzliche Informationen über ein Objekt.

Zitat:Me

Das Schlüsselwort Me verhält sich wie eine implizit deklarierte Variable. Es steht allen Prozeduren in einem Klassenmodul automatisch zur Verfügung. Wenn eine Klasse mehrere Instanzen haben kann, stellt Me eine Möglichkeit dar, um sich auf diejenige Instanz der Klasse zu beziehen, in der Code ausgeführt wird.

Es würde auch Deine Variante mit der globalen Variable funktionieren. Allerdings müsste diese in einem allgemeinen VBA-Modul deklariert werden und nicht in einem Klassenmodul wie "DieseArbeitsmappe", wie Du es probierst.

Gruß Uwe
to top
#5
Hallo

Aha, vielen Dank.
Grüße,

Hardilein
mit Excel 2003
to top


Möglicherweise verwandte Themen...
Thema Verfasser Antworten Ansichten Letzter Beitrag
  VBA Solver mit zusätzlicher Variable und Zielwert eränzen tschibolli 2 70 22.11.2016, 08:11
Letzter Beitrag: tschibolli
  Tabelle automatisch füllen Falco 6 81 16.11.2016, 17:21
Letzter Beitrag: Falco
  Variable in Makro VaterBaum 12 161 12.11.2016, 20:34
Letzter Beitrag: AlterDresdner
  Inhalt Multiselect-ListBox in Variable auslesen Rabe 3 75 28.10.2016, 12:04
Letzter Beitrag: Rabe
  Variable Nachtzeiten und Zuschläge Chimera 2 105 28.10.2016, 00:28
Letzter Beitrag: Chimera
  Zellenformeln verkürzen durch Namen definieren (variable) Woofer 2 96 27.10.2016, 15:46
Letzter Beitrag: BoskoBiati
  Globale Variablen in VBA Kash 12 192 26.10.2016, 04:28
Letzter Beitrag: schauan
  Zellen automatisch füllen, wenn eine Bedingung erfüllt Bananajo 4 129 15.10.2016, 17:20
Letzter Beitrag: schauan
  PDF aus Excel füllen DieterB 3 234 25.09.2016, 11:31
Letzter Beitrag: schauan
Question Variable Höhe /Breite eines Excel VBA-UserForms GuteFrage 2 148 25.09.2016, 11:04
Letzter Beitrag: schauan

Gehe zu:


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