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 :

Probleme avec la fonction VLookup


Sujet :

Macros et VBA Excel

  1. #1
    Membre régulier
    Inscrit en
    Mai 2007
    Messages
    142
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 142
    Points : 94
    Points
    94
    Par défaut Probleme avec la fonction VLookup
    Bonjour,
    Quelqu'un peut m'aider à comprendre l'origine de l'erreur dans la ligne contenant la fonction VLookup ?
    Il me donne l'erreur suivante : Erreur d'exécution '6' dépassement de capacité !
    Merci
    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
    Private Sub cmdvalid_Click()
     
    With ThisWorkbook.Sheets("Hiver")
    Dim iRow As Integer
     
    For iRow = 1 To 92
    Dim currentcell As Long
    Dim idxferie As Integer
     
    currentcell = .Cells(iRow, 1).Value
    'idxferie = WorksheetFunction.VLookup(currentcell, Sheets("main").Range("B14:B24"), 1, False)
    If currentcell >= CDate(Datebegin) And currentcell <= CDate(DateEnd) _
    And Weekday(currentcell) <> 1 And Weekday(currentcell) <> 7 Then
    .Cells(iRow, 2).Value = Me.NameList.Value
    Else
    .Cells(iRow, 2).Value = ""
    End If
    Next
    End With
     
    'clear the data
    Me.NameList.Value = ""
    Me.Datebegin.Value = ""
    Me.DateEnd.Value = ""
    Me.NameList.Value = ""
    Me.ButtonOUI.Value = False
    Me.ButtonNON.Value = True
    End Sub

  2. #2
    pgz
    pgz est déconnecté
    Expert éminent Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Points : 6 591
    Points
    6 591
    Par défaut
    Bonjour.

    Pour éclaircir les choses, peux-tu
    ajouter à ton code une indentation,
    sortir les instructions Dim de la boucle For ... Next
    Préciser alors quelle ligne provoque l'arrêt en erreur?

    Cordialement,

    PGZ

  3. #3
    Membre régulier
    Inscrit en
    Mai 2007
    Messages
    142
    Détails du profil
    Informations forums :
    Inscription : Mai 2007
    Messages : 142
    Points : 94
    Points
    94
    Par défaut
    Merci d'avoir répondu.
    voici une version simplifiée du problème
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub cmdvalid_Click()
     
    With ThisWorkbook.Sheets("Hiver")
    Dim currentcell As Long
    Dim idxferie As Integer
    ' definir le paramettre "currentcell" en tant que contenu de la cellule B14
    currentcell = Sheets("main").Range("B14").Value
    'calcul du numero de ligne associé a B14 dans la plage B14:B24
    idxferie = WorksheetFunction.VLookup(currentcell, Sheets("main").Range("B14:B24"), 1, False)
    ' coller ce num dans la celulle B1 de la feuil "Hiver"
    .Cells(1, 2).Value = idxferie
    End With
    End Sub

  4. #4
    pgz
    pgz est déconnecté
    Expert éminent Avatar de pgz
    Homme Profil pro
    Développeur Office VBA
    Inscrit en
    Août 2005
    Messages
    3 692
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Office VBA
    Secteur : Conseil

    Informations forums :
    Inscription : Août 2005
    Messages : 3 692
    Points : 6 591
    Points
    6 591
    Par défaut
    Re,

    Je suppose que c'est la ligne avec le VLookup qui pose pb. Le résultat est rangé dans idxferie qui est de type Integer. Peux-tu vérifier la valeur renvoyée quand l'erreur se produit?
    Ce qui est surprenant c'est que l'index colonne du VLookUp = 1. Ce qui devrait renvoyer la valeur cherchée, soit currentcell, qui est de type long.

    D'habitude, on utilise vLookUp pour trouver une ligne suivant la valeur en colonne 1 et lire dans une colonne plus à droite. La table doit donc avoir au moins 2 colonnes, ce qui n'est pas le cas.

    Peux-tu expliquer exactement ce qu tu veux faire avec le VLookUp?

    COrdialement,

    PGZ

  5. #5
    Membre du Club
    Inscrit en
    Mars 2006
    Messages
    50
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 50
    Points : 41
    Points
    41
    Par défaut
    • Première option :
      Aide Excel :
      WorksheetFunction.VLookup, méthode
      ...
      Valeur renvoyée
      Variante
      En placant la déclaration des variables currentcell et idxferie en Variant, ca fonctionne bien

    • Deuxième option :
      Par contre si tu as besoin de récupérer le n° de la ligne, dans la plage B14:B24, contenant la même valeur que la cellule B14 (en rapport avec les commentaires)
      il faut remplacer la formule VLOOKUP par EQUIV

Discussions similaires

  1. [XL-2007] Probleme avec la Fonction VLookup
    Par agd92500 dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 26/02/2014, 21h11
  2. Probleme avec la fonction rename()
    Par TheZenZen dans le forum C
    Réponses: 6
    Dernier message: 08/10/2005, 15h59
  3. [LG] Problème avec la Fonction ReadLn en fin de programme
    Par killermano dans le forum Langage
    Réponses: 6
    Dernier message: 23/07/2005, 15h16
  4. [LG]Probleme avec une fonction
    Par xavier1936 dans le forum Langage
    Réponses: 7
    Dernier message: 08/02/2005, 22h48

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