Mon problème est le suivant:
J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de
lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour
continuer la procedure en cours. Cette fonction marche trés bien avec
n'importe qu'elle programme. Mais quand je veux exécuter un autre programme
access et que je ferme celle-ci, mon programme ne reprend pas. J'ai
l'impression que pour que l'exécution du programme reprenne, il faut qu'il
n'y ait plus aucun access ouvert (Ce qui est impossible puisque le programme
s'exécute à partir d'access).
Je comprend pas puisque la fonction AppExecuter se sert du handle et que
celui-ci est unique pour chaque access ouvert.
si quelqu'un à une idée.
Option Compare Database
Option Explicit
Private Const Priorité_Normale = &H20&
Private Const Infini = -1&
Dim Name_Process As Info_Process
Dim Name_Initial As Info_Initiale
Dim ProcessOK As Long
Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _
(hObject As Long) As Boolean
Private Declare Function AppExecuter Lib "kernel32" Alias
"WaitForSingleObject" _
(ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA" _
(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, _
lpInfo_Initiale As Info_Initiale, _
lpProcessInformation As Info_Process) As Long
Private Type Info_Initiale
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 Info_Process
hProcess As Long
hThread As Long
dwProcessId As Long
dwThreadID As Long
End Type
Public Function ShellWait(AppName As String) As Boolean
Name_Initial.cb = Len(Name_Initial)
ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _
Priorité_Normale, 0&, 0&, Name_Initial, Name_Process)
If ProcessOK <> 0 Then
Call AppExecuter(Name_Process.hProcess, Infini)
Call AppFermer(Name_Process.hProcess)
ShellWait = True
Else
ShellWait = False
End If
End Function
Cette action est irreversible, confirmez la suppression du commentaire ?
Signaler le commentaire
Veuillez sélectionner un problème
Nudité
Violence
Harcèlement
Fraude
Vente illégale
Discours haineux
Terrorisme
Autre
Raymond [mvp]
Bonsoir.
la commande Shellwait envoie un paramètre msaccess.exe qui est identique au process appelant et déjà, ici, windows se mélange les pattes. Il a toujours été convenu qu'une application access devait être lancée par shell ou par automation. le shell n'apportant rien à une autre application access, il est d'usage de toujours communiquer access-access par automation, ce qui apporte un plus important à une application.
-- @+ Raymond Access MVP http://OfficeSystem.Access.free.fr/ http://users.skynet.be/mpfa/ pour débuter sur le forum
"yohann" a écrit dans le message de news:
Mon problème est le suivant: J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour continuer la procedure en cours. Cette fonction marche trés bien avec n'importe qu'elle programme. Mais quand je veux exécuter un autre programme access et que je ferme celle-ci, mon programme ne reprend pas. J'ai l'impression que pour que l'exécution du programme reprenne, il faut qu'il n'y ait plus aucun access ouvert (Ce qui est impossible puisque le programme s'exécute à partir d'access). Je comprend pas puisque la fonction AppExecuter se sert du handle et que celui-ci est unique pour chaque access ouvert.
si quelqu'un à une idée.
Option Compare Database Option Explicit
Private Const Priorité_Normale = &H20& Private Const Infini = -1& Dim Name_Process As Info_Process Dim Name_Initial As Info_Initiale Dim ProcessOK As Long
Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _ (hObject As Long) As Boolean
Private Declare Function AppExecuter Lib "kernel32" Alias "WaitForSingleObject" _ (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA" _ (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, _ lpInfo_Initiale As Info_Initiale, _ lpProcessInformation As Info_Process) As Long
Private Type Info_Initiale 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 Info_Process hProcess As Long hThread As Long dwProcessId As Long dwThreadID As Long End Type
Public Function ShellWait(AppName As String) As Boolean Name_Initial.cb = Len(Name_Initial) ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _ Priorité_Normale, 0&, 0&, Name_Initial, Name_Process) If ProcessOK <> 0 Then Call AppExecuter(Name_Process.hProcess, Infini) Call AppFermer(Name_Process.hProcess) ShellWait = True Else ShellWait = False End If End Function
Bonsoir.
la commande Shellwait envoie un paramètre msaccess.exe qui est identique au
process appelant et déjà, ici, windows se mélange les pattes.
Il a toujours été convenu qu'une application access devait être lancée par
shell ou par automation. le shell n'apportant rien à une autre application
access, il est d'usage de toujours communiquer access-access par automation,
ce qui apporte un plus important à une application.
--
@+
Raymond Access MVP
http://OfficeSystem.Access.free.fr/
http://users.skynet.be/mpfa/ pour débuter sur le forum
"yohann" <yohann@discussions.microsoft.com> a écrit dans le message de news:
036B85AE-0132-4FC4-9DEF-B49301AC4651@microsoft.com...
Mon problème est le suivant:
J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de
lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour
continuer la procedure en cours. Cette fonction marche trés bien avec
n'importe qu'elle programme. Mais quand je veux exécuter un autre
programme
access et que je ferme celle-ci, mon programme ne reprend pas. J'ai
l'impression que pour que l'exécution du programme reprenne, il faut qu'il
n'y ait plus aucun access ouvert (Ce qui est impossible puisque le
programme
s'exécute à partir d'access).
Je comprend pas puisque la fonction AppExecuter se sert du handle et que
celui-ci est unique pour chaque access ouvert.
si quelqu'un à une idée.
Option Compare Database
Option Explicit
Private Const Priorité_Normale = &H20&
Private Const Infini = -1&
Dim Name_Process As Info_Process
Dim Name_Initial As Info_Initiale
Dim ProcessOK As Long
Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _
(hObject As Long) As Boolean
Private Declare Function AppExecuter Lib "kernel32" Alias
"WaitForSingleObject" _
(ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA"
_
(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, _
lpInfo_Initiale As Info_Initiale, _
lpProcessInformation As Info_Process) As Long
Private Type Info_Initiale
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 Info_Process
hProcess As Long
hThread As Long
dwProcessId As Long
dwThreadID As Long
End Type
Public Function ShellWait(AppName As String) As Boolean
Name_Initial.cb = Len(Name_Initial)
ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _
Priorité_Normale, 0&, 0&, Name_Initial, Name_Process)
If ProcessOK <> 0 Then
Call AppExecuter(Name_Process.hProcess, Infini)
Call AppFermer(Name_Process.hProcess)
ShellWait = True
Else
ShellWait = False
End If
End Function
la commande Shellwait envoie un paramètre msaccess.exe qui est identique au process appelant et déjà, ici, windows se mélange les pattes. Il a toujours été convenu qu'une application access devait être lancée par shell ou par automation. le shell n'apportant rien à une autre application access, il est d'usage de toujours communiquer access-access par automation, ce qui apporte un plus important à une application.
-- @+ Raymond Access MVP http://OfficeSystem.Access.free.fr/ http://users.skynet.be/mpfa/ pour débuter sur le forum
"yohann" a écrit dans le message de news:
Mon problème est le suivant: J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour continuer la procedure en cours. Cette fonction marche trés bien avec n'importe qu'elle programme. Mais quand je veux exécuter un autre programme access et que je ferme celle-ci, mon programme ne reprend pas. J'ai l'impression que pour que l'exécution du programme reprenne, il faut qu'il n'y ait plus aucun access ouvert (Ce qui est impossible puisque le programme s'exécute à partir d'access). Je comprend pas puisque la fonction AppExecuter se sert du handle et que celui-ci est unique pour chaque access ouvert.
si quelqu'un à une idée.
Option Compare Database Option Explicit
Private Const Priorité_Normale = &H20& Private Const Infini = -1& Dim Name_Process As Info_Process Dim Name_Initial As Info_Initiale Dim ProcessOK As Long
Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _ (hObject As Long) As Boolean
Private Declare Function AppExecuter Lib "kernel32" Alias "WaitForSingleObject" _ (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA" _ (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, _ lpInfo_Initiale As Info_Initiale, _ lpProcessInformation As Info_Process) As Long
Private Type Info_Initiale 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 Info_Process hProcess As Long hThread As Long dwProcessId As Long dwThreadID As Long End Type
Public Function ShellWait(AppName As String) As Boolean Name_Initial.cb = Len(Name_Initial) ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _ Priorité_Normale, 0&, 0&, Name_Initial, Name_Process) If ProcessOK <> 0 Then Call AppExecuter(Name_Process.hProcess, Infini) Call AppFermer(Name_Process.hProcess) ShellWait = True Else ShellWait = False End If End Function