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 des Coordonnées d'une Cellule sur un Excel Distant


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Février 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Recherche des Coordonnées d'une Cellule sur un Excel Distant
    Bonjour à tous,

    J'essai de programmer en vba une fonction qui pourrait récupérer les coordonnées de la cellule ou se trouve le mot que je recherche (et que j'ai renseigné dans ma feuille de base) afin de récupérer la données correspondante située juste dans la cellule à droite (ces données se trouve sur un deuxième fichier Excel).

    ex :

    Classeur1 Feuill1 (en A1 le mot à trouver, et en D1 le résultat(fonction))

    ______A______B______C______D
    1___TOTO__________________A3
    2
    3

    Classeur2 Feuill1 (la liste des mots)

    ______A
    1___TUTU
    2___TATA
    3___TOTO
    4___TITI

    Merci d'avance pour votre aide.

  2. #2
    Expert éminent
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    3 906
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 3 906
    Points : 8 539
    Points
    8 539
    Par défaut
    SAlut et bienvenu (ça recrute sec en se moment )
    Il y a déjà pas mal de sujet dont tu peux t'inspirer pour faire ta macro en voila un, crée ta macro et si tu rencontre un problème n'hésite pas a nous montrer ton travail et nous ferons notre possible pour t'aider.
    A++
    Qwaz

  3. #3
    Nouveau Candidat au Club
    Inscrit en
    Février 2008
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Février 2008
    Messages : 2
    Points : 1
    Points
    1
    Par défaut
    Bonjour,

    Le Problème c'est que j'y connait rien, alors voici les premières trames de ce que j'ai pu faire mais si quelqu'un pouvait m'aider à faire fonctionner cette macro Excel, je lui en serais très reconnaissant.

    Ca n'a surement aucun sens mais ce peux servir de Base ...


    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
    43
    44
    Public xlMyApp As Excel.Application
    Public xlMyBooks As Excel.Workbooks
    Public xlMyBook As Excel.Workbook
     
    Type Resultats
        Lignes  As Long
        Adresse As String
        Valeur As Variant
    End Type
     
     
    Function RechercheExcel( _
            Chemin As String, _
            Fichier As String, _
            Feuille As String, _
            MotRecherche As String) As Variant
     
    Application.Volatile
     
    Dim Cible As String, PlagedeRecherche As String
    Dim CelluleTrouve As Range
     
    Feuille = Feuille & "$"
     
    PlagedeRecherche = "A:A" & Range("A1").End(xlDown).Row
    With Range(PlagedeRecherche)
        Set CelluleTrouve = .Find(What:=Cellule.Value, LookIn:=MotRecherche)
    End With
     
    If Not (CelluleTrouve Is Nothing) Then
        VarBte.Ligne = CelluleTrouve.Row
        VarBte.Adresse = CelluleTrouve.Address
    Else
        VarBte.Ligne = 0
    End If
    Set CelluleTrouve = Nothing
     
    If xlMyApp Is Nothing Then
        Set Source = CreateObject("Excel.Application")
        Set xlMyBooks = xlMyApp.Workbooks
        xlMyApp.Visible = True
    End If
     
    End Function
    Merci d'avance

  4. #4
    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 546
    Points
    15 546
    Par défaut
    Ok, je viens de relire ta question et il y a "distant"
    Donc faut modifier
    Tu n'es pas obligé de déclarer le classeur distant en public
    Je reprends ton code et le mien
    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
    Sub CopierLeMot()
    Dim XlApp As Object
    Dim XlCl1 As Workbook 'Classeur distant
    Dim CL2 As Workbook 'Classeur contenant la macro
    Dim FL1 As Worksheet 'Feuil1 classeur distant
    Dim FL2 As Worksheet 'Feuil1 du classeur CL2
         'Traitement classeur distant
         Set XlApp = CreateObject("Excel.Application") ' L'appli Excel distante
         DoEvents
         'Ouverture du classeur distant
         Set XlCl1  = XlApp.Workbooks.Open("Chemin distant\LeClasseur.xls")
         DoEvents
    
         'Instance de la feuil1 du classeur distant
         Set FL1 = XlApp. XlCl1.Worksheets("Feuil1")
    
         'Plage de recherche dans le classeur distant
         Plage = FL1.range("A1:A" & FL1.Range("A65536").end(xlup).row)
    
         'Instance de la feuil1 du Classeur contenant la macro
         Set FL2 = Workbooks("NomDuClasseur2.xls").worksheets("feuil1")
    'ou (tu as le choix...)
         Set CL2 = Thisworkbook 'classeur contenant les macros
         Set FL2 = CL2.worksheets("feuil1")
         'Parcours de la colonne A dans le classeur contenant la macro
         For each Cell in FL2.range("A1:A" & FL2.Range("A65536").end(xlup).row)
              Cell.Offset(0, 3) = Trouver(Cell, FL1, Plage)
         Next
    
         XlCl1.Close False 'ou true si tu veux enregistrer le classeur distant
         XlAppli.Quit 'fermeture appli distante
    
         'Enregistrement des données classeur actif
         Activeworkbook.save 
    
         'Supp des instances
         Set FL1 = Nothing
         Set FL2 = Nothing
         Set XlAppli = Nothing
         Set XlCl = Nothing
         Set Xlfl = Nothing
    End sub
    toujours sans filet.
    Tu peux tester pour nous et nous indiquer ce qui ne va pas ?
    A+

  5. #5
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Hello,

    et un truc du genre :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =ADRESSE(EQUIV(A1;'[classeur.xls]onglet'!$A:$A;FAUX);1)

  6. #6
    Expert éminent
    Avatar de cafeine
    Inscrit en
    Juin 2002
    Messages
    3 904
    Détails du profil
    Informations forums :
    Inscription : Juin 2002
    Messages : 3 904
    Points : 6 781
    Points
    6 781
    Par défaut
    Absolutely my dear, mais ça marche aussi sur un classeur fermé

Discussions similaires

  1. Réponses: 3
    Dernier message: 20/01/2014, 09h28
  2. [Toutes versions] Confusion de résultats dans recherche des occurrences d'une valeur avec Find sur des dates
    Par iperkut dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 08/11/2011, 19h07
  3. [TStringGrid] Une cellule sur plusieurs lignes.
    Par Caine dans le forum Delphi
    Réponses: 15
    Dernier message: 28/03/2007, 12h53
  4. Recherche des symboles dans une lib c++
    Par firens dans le forum MFC
    Réponses: 4
    Dernier message: 31/03/2006, 14h56
  5. Recherche des coefficients d'une matrice 3x3
    Par colorid dans le forum Algorithmes et structures de données
    Réponses: 6
    Dernier message: 25/11/2004, 16h52

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