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
  Formular füllen und 2fach speichern Tuempeltaucher 2 40 Vor 11 Stunden
Letzter Beitrag: Tuempeltaucher
  Drop Down Feld mittels gefilterter Liste füllen sunny01 8 106 26.02.2017, 20:35
Letzter Beitrag: sunny01
  Variable Ziffernfolge aus Text ermitteln user2212 7 90 21.02.2017, 15:38
Letzter Beitrag: snb
  per VBA shapes einer dynamischen Karte mit Farben und Mustern füllen laberbeat 5 108 10.02.2017, 16:12
Letzter Beitrag: Ego
  Combobox in Tabelle füllen hbboy15 3 65 06.02.2017, 10:44
Letzter Beitrag: atilla
  VBA Globale Variablen und automatisch erstellte Worksheets Hobbes95 2 75 05.02.2017, 18:33
Letzter Beitrag: Hobbes95
  Zellen mit VBA füllen Maxm 3 109 17.01.2017, 09:06
Letzter Beitrag: Maxm
  Globale Deklaration soll auch in Klasse gelten Kathrin Doppelbauer 1 71 15.01.2017, 14:15
Letzter Beitrag: Steffl
  VBA- Word Datei erstellen und Bookmarks füllen Joe 3 141 09.01.2017, 11:18
Letzter Beitrag: Joe
  Variablen füllen mit Schleife mumpel 40 990 07.12.2016, 22:37
Letzter Beitrag: snb

Gehe zu:


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