XL 2021 Faire mieux mon code

Usine à gaz

XLDnaute Barbatruc
Supporter XLD
Bonjour à toutes et à tous :)

Pour tester si un classeur est ouvert, j'ai un code :
Je dois tester 3 classeurs :
VB:
'SELECTION ICHIER RDdVs
    On Error Resume Next
    If Err <> 0 Then
        Windows("isitelImmobRdV ImenNF.xlsm").Activate
        MsgBox ("isitelImmobRdV ImenNF.xlsm OK!")
        Else
        MsgBox "isitelImmobRdV ImenNF.xlsm n'est pas ouvert"
        Application.EnableEvents = True
        Application.ScreenUpdating = True
        Exit Sub
    End If
   
    On Error Resume Next
    If Err <> 0 Then
        Windows("isitelImmobRdV SondaNF.xlsm").Activate
        MsgBox ("isitelImmobRdV SondaNF.xlsm OK!")
        Else
        MsgBox "isitelImmobRdV SondaNF.xlsm n'est pas ouvert"
        Application.EnableEvents = True
        Application.ScreenUpdating = True
        Exit Sub
    End If
   
    On Error Resume Next
    If Err <> 0 Then
        Windows("isitelImmobRdV StephanieNF.xlsm").Activate
        MsgBox ("isitelImmobRdV StephanieNF.xlsm OK!")
        Else
        MsgBox "isitelImmobRdV StephanieNF.xlsm n'est pas ouvert"
        Application.EnableEvents = True
        Application.ScreenUpdating = True
        Exit Sub
    End If
Objectif
Je voudrais tester sur le :
- 1er classeur : Si le classeur est ouvert, le test s'arrête : avec msgbox : Ouvert, et la suite de ma macro s'exécute...
- 2e. classeur : Si le classeur est ouvert, le test s'arrête : avec msgbox : Ouvert, et la suite de ma macro s'exécute...
- 3e. classeur : Si le classeur est ouvert, le test s'arrête : avec msgbox : Ouvert, et la suite de ma macro s'exécute...
- Si aucun classeur ouvert : Application.EnableEvents = True: Application.ScreenUpdating = True : Exit Sub

Je ne vois pas trop comment faire . Je cherche.....
Pourriez-vous m'aider ?
Grand merci à toutes et à tous,
Si nécessaire, je ferai un classeur test
:)
 

patricktoulon

XLDnaute Barbatruc
Bonjour lionel
VB:
Sub test2()
    mes_classeurs = "|isitelImmobRdV SondaNF.xlsm|isitelImmobRdVSondaNF.xlsm|isitelImmobRdV StephanieNF.xlsm|"
    Dim wbk As Workbook
    For Each wbk In Workbooks
        MsgBox wbk.Name
        If mes_classeurs Like "*|" & wbk.Name & "|*" Then
            Windows(wbk.Name).Activate
            Application.EnableEvents = True
            Application.ScreenUpdating = True
            Exit Sub
        Else
            MsgBox "LES CLASSEURS" & vbCrLf & Join(Split(mes_classeurs, "|"), vbCrLf) & vbCrLf & "SONT FERMÉS"
        End If
    Next
End Sub
 

Eric KERGRESSE

XLDnaute Occasionnel
Bonjour,

Une autre proposition :

VB:
Dim Message As String
Dim I As Integer


    Message = ""
    
    For I = 1 To Workbooks.Count
        With Workbooks(I)
            Select Case .Name
                   Case "isitelImmobRdV ImenNF.xlsm"
                         .Activate
                         Message = "isitelImmobRdV ImenNF.xlsm OK!"
                         Exit For
                   Case "isitelImmobRdV SondaNF.xlsm"
                         .Activate
                         Message = "isitelImmobRdV SondaNF.xlsm OK!"
                         Exit For
                   Case "isitelImmobRdV StephanieNF.xlsm"
                         .Activate
                         Message = "isitelImmobRdV StephanieNF.xlsm OK!"
                         Exit For
            End Select
        End With
    Next I
    
    If Message = "" Then
       Application.EnableEvents = True
       Application.ScreenUpdating = True
       Exit Sub
    Else
       MsgBox Message
    End If
 

dysorthographie

XLDnaute Accro
Bonjour,
VB:
Sub test()
'SELECTION ICHIER RDdVs
    If Not (IsOpen("isitelImmobRdV ImenNF.xlsm") And _
    IsOpen("isitelImmobRdV SondaNF.xlsm") And _
    IsOpen("isitelImmobRdV StephanieNF.xlsm")) Then MsgBox "Aucun  n'est ouvert": Exit Sub
End Sub
Function IsOpen(Classeur As String) As Boolean
Dim Wb As String
On Error Resume Next
Wb = Windows(Classeur).Caption
IsOpen = Not CBool(Err)
Err.Clear
On Error GoTo 0
End Function
Edite
VB:
Sub test2()
'SELECTION ICHIER RDdVs
  If IsOpen("isitelImmobRdV ImenNF.xlsm") Then TraitementFichier (Windows("isitelImmobRdV ImenNF.xlsm")): Exit Sub
 If IsOpen("isitelImmobRdV SondaNF.xlsm") Then TraitementFichier Windows("isitelImmobRdV SondaNF.xlsm"): Exit Sub
 If IsOpen("isitelImmobRdV StephanieNF.xlsm") Then TraitementFichier Windows("isitelImmobRdV StephanieNF.xlsm"): Exit Sub
 
End Sub
Sub TraitementFichier(Fichier As Workbook)
 'Traitement
 
End Sub
 
Dernière édition:

job75

XLDnaute Barbatruc
Bonjour Lionel, le fil,

Il y a évidemment de nombreuses manières de traiter la question, en voici une autre :
VB:
Sub Test()
Dim a, wb As Workbook, flag As Boolean
a = Array("isitelImmobRdV ImenNF.xlsm", "isitelImmobRdV SondaNF.xlsm", "isitelImmobRdV StephanieNF.xlsm")
For Each wb In Workbooks
    If IsNumeric(Application.Match(wb.Name, a, 0)) Then MsgBox "'" & wb.Name & "' est ouvert": flag = True
Next
If Not flag Then MsgBox "Aucun des 3 fichiers n'est ouvert"
End Sub
A+
 

Usine à gaz

XLDnaute Barbatruc
Supporter XLD
Bonsoir à tous :)
Je vous remercie encore pour vos codes qui fonctionnent nickel.

J'ai un beug sur celui de Eric KERGRESSE mais trop fatigué pour voir ce soir.
Grand Merci à tous pour m'avoir répondu.
Je vous souhaite une bonne nuit...
:)
Voilàç le classeur test.
J'ai modifié les noms des classeurs pour faire plus simple :)
 

Pièces jointes

  • classeur ouvert test.xlsm
    21.8 KB · Affichages: 3

TooFatBoy

XLDnaute Barbatruc
Bonjour,

Enrichi (BBcode):
'SELECTION ICHIER RDdVs
On Error Resume Next

If Err <> 0 Then
    Windows("isitelImmobRdV ImenNF.xlsm").Activate
    MsgBox ("isitelImmobRdV ImenNF.xlsm OK!")
Else
    MsgBox "isitelImmobRdV ImenNF.xlsm n'est pas ouvert"
    Application.EnableEvents = True
    Application.ScreenUpdating = True
    Exit Sub
End If
Euh... tu as remarqué que tu commences par tester s'il y a une erreur avant même d'avoir exécuté la moindre instruction ???


Et pourquoi mettre trois fois On Error Resume Next alors qu'il n'y a pas de On Error Goto xxx ?
 

Discussions similaires

Réponses
8
Affichages
481

Statistiques des forums

Discussions
312 207
Messages
2 086 231
Membres
103 161
dernier inscrit
Rogombe bryan