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 :

vérification de la presence d'une feuille


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de zandru
    Homme Profil pro
    Ingénieur conception mécanique
    Inscrit en
    Mars 2008
    Messages
    507
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur conception mécanique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2008
    Messages : 507
    Par défaut vérification de la presence d'une feuille
    Bonjour,
    je cherche à vérifier la présence d'une feuille dans un classeur.
    Le nom du fichier provient d'une combobox, et après avoir vérifié l'existence du fichier, je voudrais vérifier la présence de la feuille avant de pouvoir l'utiliser.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    nomdechemin = "E:\GABRIEL PERSO\GESTION VBA\AFFAIRE\" & bl.numaff.Text & ".xls"
        Dim fs As FileSystemObject
        Set fs = CreateObject("Scripting.FileSystemObject")
        If fs.FileExists(nomdechemin) = True Then
            Workbooks.Open Filename:=nomdechemin, UpdateLinks:=0, ReadOnly:=False, ignorereadonlyrecommended:=True, notify:=False
            If ActiveWorkbook.Sheets(bl.commande.Text).Exists = True Then
                ActiveWorkbook.Worksheets(bl.commande.Text).Activate
            End If
        End If
    en fait il faudrait remplacer la ligne en gras par une commande qui fonctionne !!

    Si quelqu'un a une idée...

  2. #2
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    Bonjour

    Essaye ca

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
        If fs.FileExists(nomdechemin) = True Then
            Workbooks.Open Filename:=nomdechemin, UpdateLinks:=0, ReadOnly:=False, ignorereadonlyrecommended:=True, notify:=False
            on error goto erreur
            ActiveWorkbook.Worksheets(bl.commande.Text).select
            goto suite
     erreur:
            Msgbox "La feuille " & bl.commande.texte & " n'existe pas"
            Activeworkbook.close false
            exit sub
    suite:
        End If

  3. #3
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    En reprenant l'exemple de Wilfried
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim FL1 as worksheet
        If fs.FileExists(nomdechemin) = True Then
            Workbooks.Open Filename:=nomdechemin, UpdateLinks:=0, ReadOnly:=False, ignorereadonlyrecommended:=True, notify:=False
            Set FL1 = ActiveWorkbook.Worksheets(bl.commande.Text)
            if not FL1 is nothing then msgbox "Ta feuille existe"
    Pas testé...
    Tu dis

  4. #4
    Membre éclairé Avatar de zandru
    Homme Profil pro
    Ingénieur conception mécanique
    Inscrit en
    Mars 2008
    Messages
    507
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur conception mécanique
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2008
    Messages : 507
    Par défaut
    la solution avec gestion d'erreur marche parfaitement, merci


    par contre la deuxième solution plante sur la ligne "Set FL1 ..." si la feuille n'existe pas

  5. #5
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Merci, comme ça je le saurai
    En effet, je viens de tester, il faut également une gestion d'erreur
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Dim FL1 as worksheet
        If fs.FileExists(nomdechemin) = True Then
            Workbooks.Open Filename:=nomdechemin, UpdateLinks:=0, ReadOnly:=False, ignorereadonlyrecommended:=True, notify:=False
            on error resume next
                 Set FL1 = ActiveWorkbook.Worksheets(bl.commande.Text)
            on error goto 0
            if not FL1 is nothing then msgbox "Ta feuille existe"
        Endif

  6. #6
    Membre Expert Avatar de wilfried_42
    Homme Profil pro
    Auto-entrepreneur
    Inscrit en
    Novembre 2006
    Messages
    1 427
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Vendée (Pays de la Loire)

    Informations professionnelles :
    Activité : Auto-entrepreneur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 427
    Par défaut
    re: bonjour ouskel'n'or

    Prend la solution de ouskel'n'or, elle est plus propre que la mienne (pas de goto, pas jolis les goto )

    Bonne soirée

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

Discussions similaires

  1. Vérification des saisies dans une feuille
    Par Invité dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 20/03/2009, 14h36
  2. [VB6] [Excel] Résultat d'une requete ds une feuille
    Par elifqaoui dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 07/01/2003, 17h52
  3. [VB6] [Excel] Insérer une image dans une feuille
    Par mathias dans le forum VB 6 et antérieur
    Réponses: 7
    Dernier message: 09/10/2002, 07h44
  4. Rattacher une feuille de style a un XML existant
    Par aour dans le forum XML/XSL et SOAP
    Réponses: 5
    Dernier message: 08/10/2002, 22h07
  5. [VB6] [Form] Interdire le déplacement d'une feuille
    Par Loïc dans le forum VB 6 et antérieur
    Réponses: 9
    Dernier message: 23/09/2002, 15h02

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