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 :

recherche valeur dans fichier fermé


Sujet :

Macros et VBA Excel

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 96
    Points : 56
    Points
    56
    Par défaut recherche valeur dans fichier fermé
    bonjour,

    j'ai trouvé dans un livre la fonction suivante :

    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
    Function ObtenirValeur(chemin, fichier, feuille, ref)
    'retrouve une valeur dans un classeur fermé
    Dim Arg As String
     
    's'assure de l'existence du fichier
    If Right(chemin, 1) <> "/" Then chemin = chemin & "/"
    If Dir(chemin & fichier) = "" Then
        valeurObtenue = "fichier non trouvé"
        Exit Function
    End If
     
    'crée l'argument
    Arg = "'" & chemin & "[" & fichier & "]" & feuille & "'!" & "/"
    Range 'ref).Range("A1").Address(, , x1R&C&)
     
    'execute une maccro xlm
    valeurObtenue = ExecuteExcel4Macro(Arg)
     
     
    End Function
    qui permet de recuperer une valeure dans un fichier fermé avec chemin: le lecteur et le chemin vers le fichier fermé
    fichier le nom de fichier
    feuille le nom de la feuille de calcul
    et ref la reference de la cellule...

    Seulement il doit y avoir une légère erreur au niveau de Range 'ref).Range("A1").Address(, , x1R&C&) car cela met en commentaire et donc cela bug...

    Merci de m'aider à corriger ou de me soumettre une autre fonction qui poura recuperer dans un classeur fermé...

    Lilou

  2. #2
    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
    Points : 15 543
    Points
    15 543
    Par défaut
    Regarde ici, "IV-C. Modifier les enregistrements"

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 96
    Points : 56
    Points
    56
    Par défaut
    ok merci.
    mais ça marche même si ce n'est pas une BDD mais un simple fichier excel...

    Cordialement,

    Lilou

  4. #4
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    3 317
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2005
    Messages : 3 317
    Points : 20 144
    Points
    20 144
    Par défaut
    bonsoir


    Tu peux tester cette adaptation:

    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
    Sub Test()
        MsgBox ObtenirValeur("C:\Documents and Settings\mimi\dossier", _
                            "NomClasseur.xls", _
                            "Feuil1", _
                            "B1")
    End Sub
     
     
    Function ObtenirValeur(Chemin, Fichier, Feuille, Ref)
        'retrouve une valeur dans un classeur fermé
        Dim Arg As String
     
        If Right(Chemin, 1) <> "\" Then Chemin = Chemin & "\"
     
        's'assure de l'existence du fichier
        If Dir(Chemin & Fichier) = "" Then
            ObtenirValeur = "fichier non trouvé"
            Exit Function
        End If
     
        'crée l'argument
        Arg = "'" & Chemin & "[" & Fichier & "]" & Feuille & "'!" & _
            Range(Ref).Range("A1").Address(, , xlR1C1)
     
        'execute une maccro xlm
        ObtenirValeur = ExecuteExcel4Macro(Arg)
    End Function


    bonne soirée
    michel

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 96
    Points : 56
    Points
    56
    Par défaut
    merci beaucoup ça marche.
    le problème que j'ai desormais c'est sur la valeure retournée car c'est une cellule de date. Je dois regarder si la ligne est vide ou pas j'ai donc le morceau de code suivant :
    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
    Function rechercheLigneVide(Chemin, Fichier, Feuille) As Integer
     
    Dim pas As Integer 'pour incrementer la boucle for
    Dim ligneTrouvee As Boolean 'pour savoir si le resultat a été trouvé ou non
    ligneTrouvee = False 'on initialise le resultat à faux
    pas = 1 'on incremente de +1
     
    'regarde quelle est la premiere ligne vide en commancant de la ligne 8
    For i = 1 To 500 Step pas
    Ref = "A" & i
    'si on en encore pas trouver de ligne vide
    If ligneTrouvee = False Then
        'on regarde si la ligne en cours est vide
        valeurATester = ObtenirValeur(Chemin, Fichier, Feuille, Ref)
        If valeurATester = 0 Then
            'on renvoie le numero de ligne
            'ligneVide = i
            rechercheLigneVide = i
            'on met ligne trouvee à vraie
            ligneTrouvee = True
        End If
    End If
    Next
    rechercheLigneVide = 0
     
    End Function
    j'ai essayer If valeurATester = " " Then
    If valeurATester = 0 Then
    et If valeurATester = 0/1/1900 Then
    mais rien ne semble fonctionner... comment est_ce que je peux lui dire si il n'y a pas de date entrée faire...

    Merci
    Lilou

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

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    j'ai essayer If valeurATester = " " Then
    Bonjour, ne pas mettre d'espace entre les guillemets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If valeurATester = "" Then
    LES FAQ OFFICE - LES COURS OFFICE - LES COURS EXCEL - LES LIVRES OFFICE - SOURCES VBA - ATELIER BRICOLAGE VBA

    Lorsque votre problème est solutionné, pensez à le signaler en cliquant sur le bouton au bas de la discussion.

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 96
    Points : 56
    Points
    56
    Par défaut
    Merci mais ça ne marche toujours pas...
    en fait lorsque c'est vide il me retourne 00/01/1900 et je ne sait pas pourquoi car la ligne de mon fichier est vide...

  8. #8
    Membre du Club
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    96
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 96
    Points : 56
    Points
    56
    Par défaut
    c'est bon ça marche.
    Merci

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

Discussions similaires

  1. Rechercher valeur dans fichier ini?
    Par jojo86 dans le forum Langage
    Réponses: 10
    Dernier message: 06/02/2009, 12h10
  2. recherche dans fichier fermé
    Par edelweisseric dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 05/02/2009, 18h17
  3. Rechercher une valeur dans fichier Excel depuis VBA Access
    Par tribaleur dans le forum VBA Access
    Réponses: 1
    Dernier message: 16/07/2008, 14h10
  4. Recherche adresse et valeur dans fichier fermé
    Par edelweisseric dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 31/05/2008, 21h44
  5. Tiles et recherche de valeurs dans fichier properties
    Par coyote999 dans le forum Struts 1
    Réponses: 2
    Dernier message: 05/04/2007, 11h52

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