Tek-Tips is the largest IT community on the Internet today!

Members share and learn making Tek-Tips Forums the best source of peer-reviewed technical information on the Internet!

  • Congratulations strongm on being selected by the Tek-Tips community for having the most helpful posts in the forums last week. Way to Go!

Using VBA Shell cmd to return a variable

Status
Not open for further replies.

Liam1

Programmer
Nov 7, 2002
43
GB
Hello,

I am trying to run a batch file from Access. I'm not very good at VBA, but what I would like to do is:

Return a code to my Access database when the application closes.
e.g
Shell(File.Bat)
*BTEQ Opens*
*do something for 5 minutes*
*BTEQ Closes
now my bit:
a variable is populated/created upon the called application's closure, that will allow me to trigger another function.

(The only variable it seems to return is on OPENING BTEQ)

Is this even possible?

Thanks in advance,

Liam1
 
You can check to see if the process executed by your shell command has finished with some code.

This is from Microsoft.....




Create a module and type the following lines in the Declarations section:

Code:
Option Explicit

      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 Long, 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 Long, _
         lpStartupInfo As STARTUPINFO, lpProcessInformation As _
         PROCESS_INFORMATION) As Long

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

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

Type the following two procedures in the module:



Code:
    Public Sub ExecCmd(cmdline$)
         Dim proc As PROCESS_INFORMATION
         Dim start As STARTUPINFO
         Dim ReturnValue As Integer

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

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

         ' Wait for the shelled application to finish:
         Do
            ReturnValue = WaitForSingleObject(proc.hProcess, 0)
            DoEvents
            Loop Until ReturnValue <> 258

         ReturnValue = CloseHandle(proc.hProcess)
      End Sub

Then you would call it from your form, module or where using this code

Code:
      Sub Testing()
         ExecCmd
&quot;path & file as string&quot;
Code:
         MsgBox &quot;Process Finished&quot; 'This runs after the process has finished
      End Sub


Check thread705-55856 for more info, or search on &quot;wait shell&quot;

Let me know if you need some more help.


Bill
 
Mr WillieWanka,

This has worked a treat, and is doing exactly what I want it to do 1st time, no extra coding necessary!!!!

Thanks!

Liam1.
 
Status
Not open for further replies.

Part and Inventory Search

Sponsor

Back
Top