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
    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
    Membre habitué
    Profil pro
    Inscrit en
    Octobre 2010
    Messages
    97
    Détails du profil
    Informations personnelles :
    Âge : 44
    Localisation : France

    Informations forums :
    Inscription : Octobre 2010
    Messages : 97
    Points : 135
    Points
    135
    Par défaut
    Salut aliasjadawin,

    Essai avec :


  3. #3
    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
    merci touffe, j'ai finalement enlever le set. +1 pour toi ! si des gens sont intéressés je peux poster mon code final. @+

  4. #4
    Expert éminent
    Avatar de MarcelG
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Juillet 2009
    Messages
    3 449
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 67
    Localisation : France, Maine et Loire (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Finance

    Informations forums :
    Inscription : Juillet 2009
    Messages : 3 449
    Points : 7 149
    Points
    7 149
    Billets dans le blog
    7
    Par défaut variable objet
    Bonsoir à vous deux, Bonsoir le Forum,

    Si je peux me permettre, plusieurs remarques.

    1 - Pour précision, la méthode sert à affecter une variable à un objet (classeur, feuille, cellules...), pas à une valeur; d'où ton message d'erreur.

    2 - Par contre, il faudrait ici déclarer c comme objet Range.

    3 - D'autre part, il est bienvenu de vider ces variables accessoires en fin de code, afin de libérer la mémoire.

    Ici,


+ 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