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 :

ouvrir un fichier Excel peut importe le format


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 53
    Par défaut ouvrir un fichier Excel peut importe le format
    Bonjour,

    J'ai une macro qui doit aller chercher un fichier Excel. Cependant ce fichier peut etre en format 2003 (xls) ou 2007 (xlsx). J'ai donc créé ce bout de code pour gérer la situation :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    'Ouverture du classeur
    On Error Resume Next   'Gestion de l'erreur possible d'ouverture en format 2003
    Set Classeur = ExcelApp.Workbooks.Open(Filename:="\\R.xls", UpdateLinks:=False, ReadOnly:=True) 'Ouverture sans mise à jour des liens, et mode lecture seule.
     
    'Validation de l'ouverture du fichier en format 2003
    If Classeur Is Nothing Then
        'Ouverture du classeur en format 2007
        Set Classeur = ExcelApp.Workbooks.Open(Filename:="\\R.xlsx", UpdateLinks:=False, ReadOnly:=True) 'Ouverture sans mise à jour des liens, et mode lecture seule.
    End If
    On Error GoTo 0   'Rétablissement de la gestion des erreurs normales
    Cependant cela affiche un message d'erreur si le fichier est en format 2007. C'est qu'il ne trouve pas le format 2003 alors il affiche le message d'erreur et puis il cherche le format 2007.

    Y aurait t-il une autre façon pour gérer tout ça.

    Merci d'avance

  2. #2
    Expert confirmé
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Par défaut
    Bonjour,

    Essaie ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    Dim Classeur As Workbook, Fichier As String
     
    If Dir("\\R.xls") <> "" Then
        Fichier = "\\R.xls"
    ElseIf Dir("\\R.xlsx") <> "" Then
        Fichier = "\\R.xlsx"
    Else
        MsgBox "le fichier n'existe pas"
        Exit Sub
    End If
     
    Set Classeur = Workbooks.Open(Filename:=Fichier, UpdateLinks:=False, ReadOnly:=True)

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2008
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 53
    Par défaut
    Merci beaucoup ça m'a vraiment aidé!!!!!!

  4. #4
    Inactif  

    Homme Profil pro
    cuisiniste
    Inscrit en
    Avril 2009
    Messages
    15 374
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : cuisiniste
    Secteur : Bâtiment

    Informations forums :
    Inscription : Avril 2009
    Messages : 15 374
    Billets dans le blog
    8
    Par défaut
    bonjour
    puisque apparement tu connais le nom de ton fichier pourquoi utiliser l'extention comme filtre utilise plutot le "nom"
    et voila tout

    EDIT:
    ici je fait une recherche sur tout le disque "C:" par le nom "toto" sans l 'extention des qu'il est trouvé il s'ouvre

    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
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
     
    Dim fini As Boolean
    Sub sfdsf()
     
       Dim rep As String, filtre As String
       rep = "C:" ' ici le répertoire à fouuiller, qui peut être un lecteur entier
       filtre = "toto.*" 'ici ton filtre, ' si tu en souhaites un ou le nom complet
       fini = False
       dir_dans_dir rep, filtre
    End Sub
     
    Sub dir_dans_dir(ByVal chemin As String, flt As String)
     
       If fini = True Then Exit Sub
     
       Dim Nomfic As String, nbfic As Integer, tremplin As String, i As Integer
       If Right$(chemin, 1) <> "\" Then chemin = chemin & "\"
       Nomfic = Dir$(chemin, vbDirectory)
       nbfic = 1
       Do While Nomfic <> ""
          If Nomfic <> "." And Nomfic <> ".." Then
           tremplin = chemin & Nomfic
           If GetAttr(tremplin) And vbDirectory Then '===>> tu peux même décider d'ignorer (conditions d'attributs) des dossiers complets à attributs spéciaux
            ' ListBox1.AddItem tremplin & "\" & Nomfic
             dir_dans_dir tremplin, flt
             Nomfic = Dir$(chemin, vbDirectory)
             For i = 2 To nbfic
                Nomfic = Dir$
             Next
           Else ' ====>>> c'est là que tu vas pouvoir, au bedsoin, mettre tes conditions d'attributs
             If Nomfic Like flt Then
               Workbooks.Open tremplin: fini = True
     
             End If
           End If
         End If
         Nomfic = Dir$
         nbfic = nbfic + 1
       Loop
    fin:
     
    End Sub


    au plaisir

    ou bien dans ton systeme a toi

    ici je cherche le toto.xls sans donner l'extention et puis voila


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    sub cherche_toto ()
    If Dir("C:\Users\Patrick\Desktop\toto.*") <> "" Then
        MsgBox "coucou"
    end if 
    end sub
    mes fichiers dans les contributions:
    mail avec CDO en vba et mail avec CDO en vbs dans un HTA
    survol des bouton dans userform
    prendre un cliché d'un range

    si ton problème est résolu n'oublie pas de pointer : : ça peut servir aux autres
    et n'oublie pas de voter

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

Discussions similaires

  1. [VB]ouvrir un fichier excel
    Par elasfer dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 15/10/2005, 10h31
  2. ouvrir un fichier excel coté client
    Par youss dans le forum Servlets/JSP
    Réponses: 12
    Dernier message: 27/07/2005, 15h42
  3. comment ouvrir un fichier excel ?
    Par vdavid1982 dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 13/07/2005, 13h05
  4. ouvrir un fichier Excel avec une requete perso
    Par legillou dans le forum Access
    Réponses: 9
    Dernier message: 21/06/2005, 16h14
  5. Ouvrir un fichier excel depuis access
    Par ptitegrenouille dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 03/05/2005, 12h47

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