| |  | Online-Kurs: Grundlagen des 3D-Druck-Designs für Industrieingenieure , ein Kurs
|
Autor
|
Thema: Globale Definition (333 mal gelesen)
|
fossy Mitglied Dipl.-Ing. Maschinenbau (Kraftfahrzeugtechnik)
  
 Beiträge: 943 Registriert: 07.02.2001
|
erstellt am: 17. Dez. 2001 11:01 <-- editieren / zitieren --> Unities abgeben:         
hallo alle zusammen, bei dem erstellen eines makros in excel bin ich auf ein problem gestoßen, dass ich irgendwie nicht gelöst kriege - ich hoffe, ihr könnt mir helfen. also: in einem Modul "Autostart" werden in der allgemeinen Deklaration "Public Const X = 2" festgelegt. Nun möchte ihr erreichen, dass auch sowas wie: Set LI = ThisWorkbook.Worksheets("Liste") oder auch Public Const Kostentyp(0) = "ist" global für alle module definiert wird. muss man hierfür 'n makro schreiben, was dann in allen anderen formularen und makros aufgerufen werden muss, oder deklariert werden muss? oder wie? tut mir leid, das ich hier so "umgangssprachlich" hantieren muss, aber ist halt nur "amateurhaft"  ------------------ CU fossy [Diese Nachricht wurde von fossy am 17. Dezember 2001 editiert.] Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
Fan-ME10 Mitglied DV-Adminstrator, Konstrukteur
  
 Beiträge: 543 Registriert: 21.08.2001 Erare humanum est
|
erstellt am: 18. Dez. 2001 14:54 <-- editieren / zitieren --> Unities abgeben:          Nur für fossy
Hallo fossy, also die globale Definition einer Variablen geschieht im "Modulkopf" d.h. am Anfang des jeweiligen Programmmoduls, in dem sämtlichen relevanten Macros stehen, wie z.B.: Dim Dname As String Die Variable "Dname" kannst Du dann mit: Dname="Bespielname" oder sonst wie belegen. Ich glaube aber, das dies Verfahren nicht Modulübergreifend funktioniert. Viel Erfolg Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
StefanBerlitz Ehrenmitglied V.I.P. h.c. IT Admin (CAx)

 Beiträge: 8756 Registriert: 02.03.2000 SunZu sagt: Analysiere die Vorteile, die du aus meinem Ratschlag ziehst. Dann gliedere deine Kräfte entsprechend und mache dir außergewöhnliche Taktiken zunutze.
|
erstellt am: 19. Dez. 2001 09:26 <-- editieren / zitieren --> Unities abgeben:          Nur für fossy
Hallo fossy, es kommt nur darauf an, wo und wie du die Variablen und Konstanten deklarierst. Ich hab dir mal die gängisten Zusammengestellt. Code:
' Hier ist der Kopf von einem Modul ' globale Definitionen in allen Modulen bekannt Global Const glbStr = "globaler String" Global glbVar As String' überall auf Modulebene bekannt Const mglbStr = "modul String" Dim mglbVar As String Sub beispiel() ' nur in Prozedur bekannt Const lokStr = "lokaler String" Dim lokVar As String glbVar = "globale stringvariable aus modul 1" mglbVar = "modulspezifische Variable aus modul 1" End Sub
Ich hoffe, das hilft dir weiter, ciao Stefan ------------------ Inoffizielle Solidworks Hilfeseite http://solidworks.cad.de EMail: Stefan.Berlitz@solidworks.cad.de Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
fossy Mitglied Dipl.-Ing. Maschinenbau (Kraftfahrzeugtechnik)
  
 Beiträge: 943 Registriert: 07.02.2001
|
erstellt am: 19. Dez. 2001 09:45 <-- editieren / zitieren --> Unities abgeben:         
hi, danke zunächst für eure bemühungen. leider ist das, was ich brauch noch nicht dabei  also: das problem ist, dass ich in jedem makro Set LI = ThisWorkbook.Worksheets("Liste") für meine fest definierten Tabellenblätter definieren möchte. das heißt, ich habe mehrere formulare und module, darin wieder mehrere makros - und in jedem makro, in dem ich "LI" als "abkürzung" für ThisWorkbook.Worksheets("Liste") verwenden möchte muss ich diesen paramter neu setzen. also?  ------------------ cu fossy Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP |
| Anzeige.:
Anzeige: (Infos zum Werbeplatz >>)
 |