Wirken sich Application.OnKey und Application.CommandBars auf andere geöffnete Excel-Dateien aus?

Antwort

Ja, sowohl `Application.OnKey` als auch `Application.CommandBars` wirken sich auf die gesamte Excel-Anwendung aus – und damit auf **alle geöffneten Arbeitsmappen** (Excel-Dateien) in dieser Instanz von Excel. **Details:** - **Application.OnKey:** Mit dieser Methode wird das Verhalten von Tastenkombinationen global für die gesamte Excel-Anwendung geändert. Wenn du z.B. mit `Application.OnKey "^s", "MeinMakro"` eine Tastenkombination belegst, gilt das für alle geöffneten Arbeitsmappen, nicht nur für die, in der das Makro ausgeführt wurde. - **Application.CommandBars:** Änderungen an CommandBars (z.B. Hinzufügen, Entfernen oder Anpassen von Symbolleisten oder Menüs) wirken sich ebenfalls auf die gesamte Excel-Oberfläche aus. Auch hier sind alle geöffneten Dateien betroffen. **Fazit:** Beide Methoden sind **anwendungsweit** (application-wide) und nicht auf eine einzelne Arbeitsmappe beschränkt. Änderungen bleiben aktiv, bis sie explizit zurückgesetzt werden oder Excel neu gestartet wird. **Tipp:** Wenn du solche Änderungen vornimmst, solltest du beim Schließen deiner Datei oder beim Deaktivieren deines Add-Ins die Änderungen wieder rückgängig machen, um unerwünschte Effekte für andere Dateien zu vermeiden.

Kategorie: Software Tags: Excel VBA Makro
Neue Frage stellen

Verwandte Fragen

Wie kann ich mit einem Excel-Makro alle Blätter einer Datei ausblenden, außer dem Blatt 'Anfang'?

Um in Excel per Makro (VBA) alle Blätter außer dem Blatt "Anfang" auszublenden, kannst du folgenden VBA-Code verwenden: ```vba Sub AlleBlätterAusblendenAußerAnfang()... [mehr]

Wie kann man ein Excel-Blatt per Makro aus- und einblenden?

Um in Excel per Makro (VBA) ein Arbeitsblatt auszublenden oder einzublenden, kannst du folgenden VBA-Code verwenden: **Blatt ausblenden:** ```vba Sub BlattAusblenden() Worksheets("Blattname&... [mehr]

Wie kann man mehrere Sheets in Excel mit VBA gleichzeitig sichtbar machen?

In VBA (Visual Basic for Applications) kannst du mehrere Arbeitsblätter nicht direkt in einer Zeile wie in deinem Beispiel sichtbar machen. Der Ausdruck `Sheets("TP1", "TP2").... [mehr]

Sollte man für die Platzierung der Balken in einem Gantt-Diagramm mit Excel-Makro cm in pt im Arbeitsblatt oder im Makro umrechnen?

Es ist grundsätzlich empfehlenswert, die Umrechnung von Zentimetern (cm) in Punkt (pt) direkt im Makro vorzunehmen, nicht im Arbeitsblatt. Dafür sprechen folgende Gründe: 1. **Flexibil... [mehr]

Wie kann man mit einem Excel-Makro ein Rechteck in der Standardfarbe Orange (Farbcode 49407) ausfüllen?

Um in Excel per Makro (VBA) ein Rechteck mit der Standardfarbe Orange (Farbcode 49407) auszufüllen, kannst du folgenden VBA-Code verwenden: ```vba Sub RechteckOrangeFüllen() Dim shp As... [mehr]

Wie beende ich ein Excel-Makro nach einer MsgBox mit vbYesNo bei Nein per Exit Sub, während es bei Ja fortgesetzt wird?

Das kannst du mit einer einfachen If-Abfrage umsetzen. Beispiel: ```vba If MsgBox("Möchtest du fortfahren?", vbYesNo + vbQuestion, "Bestätigung") = vbNo Then Exit Su... [mehr]

Wie ruft man ein Excel-Makro mit Call auf und übergibt einen Wert?

Um in Excel VBA (Makros) eine Prozedur mit `Call` aufzurufen und dabei einen Wert zu übergeben, gehst du wie folgt vor: **Beispiel:** 1. **Prozedur mit Parameter definieren:** ```vba Sub... [mehr]

Kann ein Excel-Makro die Funktion "Direkte Zellbearbeitung zulassen" ein- und ausschalten?

Nein, ein Excel-Makro (VBA) kann die Option „Direkte Zellbearbeitung zulassen“ nicht direkt ein- oder ausschalten. Diese Einstellung befindet sich unter **Datei > Optionen > Erweiter... [mehr]

Kann man das Excel-Makro 'Workbook_SheetBeforeRightClick' ohne Neustart aufheben?

Ja, du kannst das Excel-Makro `Private Sub Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean)` ohne Neustart von Excel "aufheben" bzw. deaktivieren,... [mehr]

Wie kann ich mit einem Excel-Makro die Zeile 22 ausblenden?

Um in Excel per Makro (VBA) die Zeile 22 auszublenden, kannst du folgenden VBA-Code verwenden: ```vba Rows(22).Hidden = True ``` So gehst du vor: 1. Drücke `ALT + F11`, um den VBA-Editor zu &o... [mehr]