IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Macros et VBA Excel Discussion :

Tester si 1 fichier excel est déjà ouvert


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Décembre 2007
    Messages : 122
    Points : 68
    Points
    68
    Par défaut Tester si 1 fichier excel est déjà ouvert
    le forum !!

    Principe rechercher : à l'ouverture du fichier EncoursProduction.xlsm, je lance une pocédure TestEncoursProduction pour savoir si ce fichier EncoursProduction.xlsm est déjà ouvert par un autre utilisateur réseau.
    Si ce fichier est déjà ouvert, je demande à l'utilisateur de le fermer.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    Sub TestEncoursProduction()
     
    Dim Reponse As Integer
     
    If FichierEstOuvert("R:\Informatique\EncoursProduction.xlsm") Then
       Reponse = MsgBox("EncoursProduction.xlsm est actuellement ouvert par un autre utilisateur!" & vbCr & vbCr & "Merci de le fermer pour poursuivre...", vbExclamation + vbOKOnly)
       If Reponse = vbOK Then
            Workbooks("EncoursProduction.xlsm").Close False
       End If
    End If
     
    End Sub
     
    Function FichierEstOuvert(ByRef FichierTest As String) As Boolean
     
    Dim Fichier As Long
     
    On Error GoTo Erreur
    Fichier = FreeFile
    Open FichierTest For Input Lock Read As #Fichier
    Close #Fichier
    FichierEstOuvert = False
    Exit Function
    Erreur:
        FichierEstOuvert = True
    End Function
    Problème rencontré : systématiquement en lançant cette procédure le programme me retourne l'info que le fichier EncoursProduction.xlsm est déjà ouvert même si ce n'est pas le cas

    Une petite idée ????

    @+ Jean

  2. #2
    Membre éclairé
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    752
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2008
    Messages : 752
    Points : 832
    Points
    832
    Par défaut
    C'est un peu normal que ça marche pas: l'ouverture de fichier en principe ça ne plante pas si le fichier existe (sauf si le fichier est utilisé une application en cours).

    Essaye plutôt de mettre le Close avant le Open: si Close échoue c'est qu'il n'y a pas de fichier ouvert à fermer.
    Corrige donc ton code en conséquence.

  3. #3
    Membre du Club
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    122
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations forums :
    Inscription : Décembre 2007
    Messages : 122
    Points : 68
    Points
    68
    Par défaut
    Merci decondelite pour ta réponse!!!

    Je cherchai en parallèle, et pour résoudre mon pb il faut simplement tester si le fichier est en lecture seule :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    Workbooks("EncoursProduction.xlsm").Activate
    If ActiveWorkbook.ReadOnly Then 'test si le fichier est en lecture seule
        MsgBox ("EncoursProduction.xlsm est actuellement ouvert par un autre utilisateur!" & vbCr & vbCr & "Merci de l'ouvrir ultérieurement..."), vbExclamation + vbOKOnly
        Workbooks("EncoursProduction.xlsm").Close False 'fermeture du fichier sans enregistrement
        Else
        FmIdentification.Show
    End If

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Tester si un fichier excel est ouvert
    Par h2qutc dans le forum Général Python
    Réponses: 1
    Dernier message: 10/12/2013, 11h52
  2. Tester si un fichier excel est déjà ouvert
    Par Marsupio dans le forum VBScript
    Réponses: 6
    Dernier message: 08/01/2011, 12h24
  3. [Toutes versions] Tester si un fichier excel est ouvert
    Par vivi4561 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 13/08/2009, 14h36
  4. Tester si un fichier excel est déjà ouvert
    Par richard038 dans le forum Delphi
    Réponses: 3
    Dernier message: 08/10/2006, 14h01
  5. [VB6] (Pilote Isam) Tester si un fichier excel est ouvert
    Par Requin15 dans le forum VB 6 et antérieur
    Réponses: 30
    Dernier message: 20/03/2006, 17h57

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo