HERBERS Excel-Forum - die Beispiele

Thema: Notepad aufrufen und Routine nach Beenden fortsetzen

Home

Gruppe

API

Problem

Notepad soll aufgerufen und das VBA-Programm fortgesetzt werden, wenn Notepad beendet wird.

Lösung
Geben Sie den nachfolgenden Code in ein Standardmodul ein und weisen Sie ihn einer Schaltfläche zu.
StandardModule: Modul1

Private Type STARTUPINFO
   cb As Long
   lpReserved As String
   lpDesktop As String
   lpTitle As String
   dwX As Long
   dwY As Long
   dwXSize As Long
   dwYSize As Long
   dwXCountChars As Long
   dwYCountChars As Long
   dwFillAttribute As Long
   dwFlags As Long
   wShowWindow As Integer
   cbReserved2 As Integer
   lpReserved2 As Long
   hStdInput As Long
   hStdOutput As Long
   hStdError As Long
End Type

Private Type PROCESS_INFORMATION
   hProcess As Long
   hThread As Long
   dwProcessID As Long
   dwThreadID As Long
End Type

Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal _
   hHandle As Long, ByVal dwMilliseconds As Long) As Long

Private Declare Function CreateProcessA Lib "kernel32" (ByVal _
   lpApplicationName As String, ByVal lpCommandLine As String, ByVal _
   lpProcessAttributes As Long, ByVal lpThreadAttributes As Long, _
   ByVal bInheritHandles As Long, ByVal dwCreationFlags As Long, _
   ByVal lpEnvironment As Long, ByVal lpCurrentDirectory As String, _
   lpStartupInfo As STARTUPINFO, lpProcessInformation As _
   PROCESS_INFORMATION) As Long

Private Declare Function CloseHandle Lib "kernel32" _
   (ByVal hObject As Long) As Long

Private Declare Function GetExitCodeProcess Lib "kernel32" _
   (ByVal hProcess As Long, lpExitCode As Long) As Long

Private Const NORMAL_PRIORITY_CLASS = &H20&
Private Const INFINITE = -1&

Public Function ExecCmd(cmdline$)
   Dim proc As PROCESS_INFORMATION
   Dim start As STARTUPINFO

   ' Initialize the STARTUPINFO structure:
   start.cb = Len(start)

   ' Start the shelled application:
   ret& = CreateProcessA(vbNullString, cmdline$, 0&, 0&, 1&, _
      NORMAL_PRIORITY_CLASS, 0&, vbNullString, start, proc)

   ' Wait for the shelled application to finish:
      ret& = WaitForSingleObject(proc.hProcess, INFINITE)
      Call GetExitCodeProcess(proc.hProcess, ret&)
      Call CloseHandle(proc.hThread)
      Call CloseHandle(proc.hProcess)
      ExecCmd = ret&
End Function

Sub Form_Click()
   Dim retval As Long
   retval = ExecCmd("notepad.exe")
   MsgBox "Process Finished, Exit Code " & retval
End Sub

Beiträge aus dem Excel-Forum zu den Themen API und Anwendung

Excel to Word Kapitel VBA Anfangskapital berechnen
Laufzeitfehler 1004: Anwendungs- oder objektorient Gestapelte Säulen-Diagramm: Ich kapier's nicht
Googel Maps API in Excel VBA einfügen Exel immer in neuer Anwendung öffnen
Berechnung vom Endkapital anwendungen öffnen
API? - xl-Parameter aus Long-Wert bestimmen Berechnung Kapitalanlage
VBA Anwendung schließen Beliebige Anwendung in VBA schließen
Telefonnummer auslesen per TAPI Läuft RSAPI.DLL mit WIN2000 und XP?
AW: Fertige Anwendungen/Formulare Fertige Anwendungen/Formulare.
JAVA API mit VBA verwenden Anwendungs- oder objektori. Fehler
Laufende Anwendung ermitteln und beenden Laufzeitfehler 1004, Anwendungs und obj.
eine datei in anwendung Diagramme in Vektorformat für andere Anwendungen?
Nur eine Mappe pro Anwendung Anwendung im Vordergrund
Anwendungs- oder objektdefinierter Fehler andere anwendung steuern, mauszeiger auslesen?
if then Anwendung in einem Makro MsgBox anzeigen / Zellen auswählen / Anwendung ?
Formatierung für fremde Anwendung Meldung bei nicht geöffneter Anwendung
Name der aktiven Anwendung Anwendungs- oder Objektbezogener Fehler
Anwendungen in verschiedenen Fenstern öffnen Papierformat speichern
Anwendungs- oder objektdefinierter Fehler verschiedene Papierquele beim Drucken
Entnahme mit Kapitalverzehr Berechnung Endkapital / Zinsen
Druck auf Papier und PDF mit und ohne Logo Problem mit dem Schließen der Excel-Anwendung
Frage zur RSAPI.DLL Anwendungen schliessen und Windows herunterfahren
Anwendungsfehler With ThisWorkbook.Worksheets ... Kombination Seitenumbruch Papierformat Anpassen
Hilfe bei der Fehlersuche (API) Hardcopy aus anderer Anwendung einfügen
Frage zu XKAPITALWERT API-Zugriff
Endkapital? bei unterschiedlichen Zahlungen API für Tastaturpuffer auslesen