Mehrere Makros automatisch starten
#1
Moin zusammen,
wie kann ich diverse Makros mittels Button starten?

Ich habe bereits einiges aus dem Netz dazu gefunden, aber irgendwie funktioniert das alles nicht.

Mein letzter Versuch:

Sub Button7_Click()
   
    Call Start_Clean        (Start_Clean und Start_Repair sind die Makros)
    Call Start_Repair
   
End Sub
Antworten Top
#2
Hi,

und was genau funktioniert da jetzt nicht?
Antworten Top
#3
Verzichte in VBA auf 'select' "Activate' and 'Call'


Code:
Sub Button7_Click()
  Start_Clean
  Start_Repair
End Sub
Zum übersetzen von Excel Formeln:

http://dolf.trieschnigg.nl/excel/index.p...gids=en+de
Antworten Top
#4
Select und Activate - klar. Aber magst Du mir/uns erklären, weshalb Call bei Dir auf der No-Go-Liste steht?
Antworten Top
#5
Hi Boris,

das sagt MS:


Zitat:Sie müssen das Call-Schlüsselwort beim Aufrufen einer Prozedur nicht verwenden. Wenn Sie das Call-Schlüsselwort jedoch verwenden, um eine Prozedur aufzurufen, die Argumente erfordert, muss argumentlist in Klammern eingeschlossen werden. Wenn Sie das Call-Schlüsselwort weglassen, müssen Sie auch die Klammern um argumentlist weglassen. Wenn Sie eine Call-Syntax verwenden, um eine systeminterne oder eine benutzerdefinierte Funktion aufzurufen, wird der Rückgabewert der Funktion verworfen.
Gruß

Edgar

Meine Antworten sind freiwillig und ohne Gewähr!
Über Rückmeldungen würde ich mich freuen.
Antworten Top
#6
Hi Edgar,

ich weiß, dass Call nur optional ist. Wenngleich ich hier keine Argumente sehe, ist es doch logisch, dass man diese - sofern vorhanden - mit Call klammern muss.
Ist doch das Selbe wie bei:

Code:
MsgBox "Hallo"

Wenn man den Rückgabewert möchte, muss es lauten:

Code:
If MsgBox("Hallo", vbYesNo) = vbYes Then

Das beantwortet aber nicht meine Frage.
Antworten Top
#7
Moin,
danke für die Diskussion und Erklärungen, hat dennoch nicht geholfen.

Ich habe folgendes wie angegeben getestet:

Sub Button7_Click()
   
    Start_Clean
    Start_Repair
   
End Sub


Ich habe diesen Code unter meinem Code gehangen und in ein separates Modul eingefügt. Jeweils das Makro dem Button7 zugewiesen und dann kommt eine Fehlermeldung (siehe Bild).


Angehängte Dateien Thumbnail(s)
   
Antworten Top
#8
Fang mal an mit VBA Grundlagen:

Ein Prozedur (Makro) <> macromodule
Zum übersetzen von Excel Formeln:

http://dolf.trieschnigg.nl/excel/index.p...gids=en+de
Antworten Top
#9
Moin Björn,

kann das sein, dass Deine beiden Makros in Modulen liegen, die den gleichen Namen tragen? Darauf deutet nämlich die Fehlermeldung hin. In diese Falle bin auch schon getappt und habe mich anschließend doof gesucht. Seither verwende ich für alles: Variablen, Userform, Modulnamen usw. immer Bezeichner mit einem erkennbaren Präfix, was das versehentliche Verwenden von geschützten VBA-Begriffen vermeidet.

In Deinem Beispiel:  Module heißen bei mir modStart_Clean. Das darin enthaltene Makro(Sub) darf dann gerne Start_Clean heißen.
Eine kleine Liste meiner persönlichen Nomenklatur findest Du hier. Sie orientiert sich an der sog. Ungarischen Notation.

@Boris: Ob man Makros mit oder ohne Call aufruft, macht (außer den Klammern für Parameter) keinen Unterschied. Man hat mit Call aber den Vorteil, dass der Code klarer wird. Als Alternative nutze ich gelegentlich ein Aufruf nach diesem Schema: modStart_Clean.StartClean. Das hat beim Coden den gleichen Vorteil wie das z.B. in Tabellen vorangestellte Me.: Der VBE-Autosense bietet die vorhandenen Items direkt an. Von snb ist dazu keine Antwort zu erwarten. Das wäre zu viel Text für ihn. Es war schon die Differenzierung zwischen Select und Select Case too much ... Wink

Schöne Grüße!

d`r Bastler von den VBAsteleien.de
Win 10 & 11, Office 2019 & 2021 & macOS X.15, XL 2019
Antworten Top
#10
Noch schlimmer ist, daß diese Webpage https://excelformeln.herber.de/ nog immer 7 oder mehr 'dead links' hat.
Zum übersetzen von Excel Formeln:

http://dolf.trieschnigg.nl/excel/index.p...gids=en+de
Antworten Top


Gehe zu:


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