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 d'une valeur dans une colonne et copie [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Homme Profil pro
    Chargé d'Etudes Statistiques
    Inscrit en
    Novembre 2010
    Messages
    79
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Chargé d'Etudes Statistiques
    Secteur : Finance

    Informations forums :
    Inscription : Novembre 2010
    Messages : 79
    Points : 98
    Points
    98
    Par défaut recherche d'une valeur dans une colonne et copie
    Bonjour, mon but est de faire, via une macro, une recherche d'une valeur (par Ctrl+H en fait) et pour chaque adresse renvoyée, copier la ligne entière et coller chacune de ces lignes l'une à la suite des autres dans une nouvelle feuille.

    Voici mon code:

    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 recherche_par_reseau()
     
        Dim critere
        Dim c
        Dim firstadress
        Dim i As Integer
     
     
     
        i = 2
     
        Set critere = Worksheets("Formulaire").Range("D19").Value 'l'erreur est ici: incompatibilité de type
     
        If Not (IsEmpty(Worksheets("Formulaire").Range("D19"))) Then
             With Worksheets("Base_de_données").Range("B:B")
     
                Set c = .Find(critere, LookIn = xlValues)
     
                    If Not c Is Nothing Then
     
                        firstAddress = c.Address
     
                        Do
                            c.EntireRow.Copy
                            Worksheets("Recherche").Range("A" & i).Paste
                            Set c = .FindNext(c)
                            i = i + 1
                        Loop While Not c Is Nothing And c.Address <> firstAddress
                    End If
                End With
     
            End If
     
     
     
     
     
     
     
    End Sub
    Si quelqu'un peut m'aider...je vous en remercie d'avance.

  2. #2
    Expert éminent
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    3 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 3 453
    Points : 6 871
    Points
    6 871
    Par défaut
    Bonsoir,

    Explications dans le code :
    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
     
    Sub recherche_par_reseau()
     
        Dim critere
        Dim c As Range
        Dim firstadress As String
        Dim i As Integer
     
        i = 2
     
        'tu cherche à affecter à une variable de type Variant que tu définie comme objet (Set) une valeur (Value)
        'ou c'est :
        '"Set critere = Worksheets("Formulaire").Range("D19")" <<< dans ce cas critere est un objet Range
        'et ensuite :
        'Valeur = critere.Value
        'ou :
        critere = Worksheets("Formulaire").Range("D19").Value '<<< dans ce cas critere est fonction du type de Value
     
     
        If Not (IsEmpty(Worksheets("Formulaire").Range("D19"))) Then
            With Worksheets("Base_de_données").Range("B:B")
     
                Set c = .Find(critere, LookIn = xlValues)
     
                If Not c Is Nothing Then
     
                    firstAddress = c.Address
     
                    Do
     
                        c.EntireRow.Copy Worksheets("Recherche").Range("A" & i)
                        Set c = .FindNext(c)
                        i = i + 1
     
                    Loop While Not c Is Nothing And c.Address <> firstAddress
     
                End If
     
            End With
     
        End If
     
    End Sub
    Hervé.

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 13/04/2015, 11h17
  2. Réponses: 2
    Dernier message: 22/04/2008, 16h21
  3. Recherche une valeur d'une cellule dans une colonne d'une autre feuille
    Par kourria dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 21/06/2007, 13h48
  4. Réponses: 1
    Dernier message: 25/09/2006, 17h15
  5. Mettre une valeur d'une table dans une variable
    Par Raphou96 dans le forum Access
    Réponses: 5
    Dernier message: 06/02/2006, 15h19

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