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 du numéro de ligne d'une date avec la fonction FIND


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Novembre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Novembre 2019
    Messages : 2
    Par défaut Recherche du numéro de ligne d'une date avec la fonction FIND
    Bonjour à tous,

    Je suis débutant en VBA et je me confronte à un problème avec la fonction FIND.
    En effet, mon objectif est de remplir automatiquement un tableau à partir d'un tableau de donnée. ainsi je recherche la date de mon tableau de donnée dans le tableau finale afin d'avoir la ligne (et même chose pour une deuxième date mais en colonne) et donc de copier une valeur dans la cellule colonne et ligne correspondante
    J'ai malheureusement un problème avec la fonction find du type erreur 424 objet requis.

    Pour que cela soit plus clair, je vous met mon code ci dessous : (le copier coller de am valeur n'est pas encore présent)

    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
     
    Sub Execute()
     
    Dim t0 As Date 'T0
    Dim C As Integer 'colonne correspondant au T0
    Dim datemaj As Date 'date de maj
    Dim L As Integer'ligne correspondant a la date de maj
    Dim nb_ligne As Integer 'correspond au nombre de ligne max dans le tableau de données
    Dim qte As Integer ' correspond à la quantité de produit
    Dim i As Integer
     
     
    Application.ScreenUpdating = False
     
    nb_ligne = Sheets("Données à remplir").Range("A" & Rows.Count).End(xlUp).Row
    i = Sheets("Données à remplir").Range("A1")
    For i = i To nb_ligne 'pour chaque ligne de mon tableau de donnée je veux comparer les deux date afin de copier qte dans le tableau cible 
        With Sheets("Données à remplir")
            t0 = .Cells(i, 5).Value
            datemaj = .Cells(i, 1).Value
            If Not .Cells(i, 6) = "Signé" Then
                qte = .Cells(i, 6).Value
            End If
     
        End With
        With Sheets("Historical data")
            If Not .Columns(1).Find(t0, lookAt:=xlWhole).Row Is Nothing Then 'je vérifie si il a trouvé la ligne sinon on passe car L ne peut pas avoir la valeur nothing
               L = .Columns(1).Find(t0, lookAt:=xlWhole).Row 'L prend la valeur de la ligne correspondante
            End If
        End With
    '        C = Sheets("Historical data").Rows(4).Find(datemaj, LookIn:=xlValues, lookAt:=xlWhole).Columns 'c'est en commentaire car je veux d'abord régler le problème de la ligne
    '        Sheets("Historical data").Cells(L, C) = qte
    Next
    End sub

    JE pense que le problème n'est pas trop complexe mais j'avoue que je suis à court d'idée pour régler ce problème..
    Merci d'avance à vous qui allez m'aider.

  2. #2
    Membre Expert
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 817
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 817
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Dans la syntaxe : If Not GnaGna Is Nothing, GnaGna doit être un objet.

    .Columns(1).Find(t0, lookAt:=xlWhole).Row n'est pas un objet, au mieux un numéro de ligne…

    Pour utiliser la méthode Find, rien de tel que d'utiliser un objet, ici un Range.
    Exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
        Dim R As Range
        With Sheets("Historical data")
           Set R = .Columns(1).Cells.Find(t0, lookAt:=xlWhole)
            If Not R Is Nothing Then 'je vérifie si il a trouvé la ligne cellule sinon on passe car L ne peut pas avoir la valeur nothing zéro
               L = R.Row 'L prend la valeur de la ligne correspondante
            Else
    'traitement si pas trouvé, au cazou
            End If
        End With

  3. #3
    Candidat au Club
    Homme Profil pro
    Chargé d'affaire
    Inscrit en
    Novembre 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loiret (Centre)

    Informations professionnelles :
    Activité : Chargé d'affaire

    Informations forums :
    Inscription : Novembre 2019
    Messages : 2
    Par défaut
    c'est parfait j'ai compris la subtilité du nothing ! Merci !

    Pour info et ceux qui ont le même problème mon code est devenu :
    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
     
     With Sheets("Historical data")
            Set x = .Columns("A:A").Find(t0, lookAt:=xlWhole)
            Set y = .Rows("1:1").Find(datemaj, lookAt:=xlWhole)
     
            If Not (x Is Nothing And y Is Nothing) Then
                C = x.Row
                L = y.Column
                If Sheets("Historical data").Cells(L, C) = "" Then
                    Sheets("Historical data").Cells(L, C) = qte
                Else
                    Sheets("Historical data").Cells(L, C) = Sheets("Historical data").Cells(L, C).Value + qte
                End If
     
            Else
                Sheets("Données à remplir").Cells(i, 7) = "Erreur"
            End If
        End With

  4. #4
    Expert éminent Avatar de Menhir
    Homme Profil pro
    Ingénieur
    Inscrit en
    Juin 2007
    Messages
    16 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2007
    Messages : 16 037
    Par défaut
    Je te déconseille l'utilisation de Find pour une date.
    Pour une valeur numérique ou une chaine de caractère, ça fonctionne bien mais pour une valeur formatée (comme une date), c'est souvent problématique.

    Je te conseille plutôt d'utiliser une des fonctions de recherche d'Excel (EQUIV, VLOOKUP, etc.) via un WorksheetFunction ou un Evaluate.

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

Discussions similaires

  1. [C#] Comment récupérer le numéro de semaine d'une date ?
    Par farfadet dans le forum Windows Forms
    Réponses: 9
    Dernier message: 17/07/2013, 16h33
  2. [XL-2010] Liste déroulante, recherche du numéro de ligne d'une info de la liste
    Par Patapong dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 26/01/2013, 21h21
  3. Rajouter les numéros de ligne dans une colone d'une requete
    Par AntiSAL dans le forum MS SQL Server
    Réponses: 7
    Dernier message: 02/11/2005, 19h07
  4. Afficher le numéro de ligne dans une requete SELECT
    Par tilb dans le forum Langage SQL
    Réponses: 4
    Dernier message: 01/09/2004, 10h20
  5. [JSP] Affichage numéro de ligne d'une exception
    Par PhoneKilleR dans le forum Servlets/JSP
    Réponses: 12
    Dernier message: 23/09/2003, 14h59

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