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 :

Tableau et UBound


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Octobre 2005
    Messages
    908
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 908
    Par défaut Tableau et UBound
    Bonjour,

    j'aimerais redimensionner un tableau dans une boucle...
    Comment agrandir le tableau d'1 en 1 ?
    J'ai essayé :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Dim tableau() As Long
     
    debut
        ReDim Preserve tableau(UBound(tableau)+1)
        tableau(UBound(tableau)+1) = xxx
    fin
    mais j'obtiens une erreur :
    Erreur d'exécution '9':
    L'indice n'appartient pas à la sélection.
    A votre avis, comment faire ?
    Merci d'avance !

  2. #2
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    Bonsoir,
    ci-dessous un extrait de code pour d'autres finalités mais tu peux t'en inspirer

    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
    Dim x As Integer, z As Integer, deb() As Integer, fin() As Integer
    Dim DerniereLigne As Integer
     
    DerniereLigne = ActiveSheet.Range("D65536").End(xlUp).Row
     
    '*****************************************************************************************************
    'alimente les deux tableaux debut et fin des noms à définir
    z = 1
    ReDim deb(2)
    ReDim fin(2)
    deb(1) = 3
     
    For x = 3 To DerniereLigne
    If Range("a" & x).Interior.ColorIndex = 48 Then ' code couleur
    deb(z + 1) = Range("a" & x).Row
    fin(z) = Range("a" & x - 1).Row
    z = z + 1
    ReDim Preserve deb(z + 1)
    ReDim Preserve fin(z + 1)
    End If
    Next x
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

  3. #3
    Membre Expert
    Homme Profil pro
    Développeur VBA Access
    Inscrit en
    Avril 2006
    Messages
    1 109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur VBA Access

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 109
    Par défaut
    Bonsoir,

    tu redimensionnes le tableau mais une fois redimensionner tu affectes au-delà du dernier indice. Retire le +1 dans cette ligne

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    tableau(UBound(tableau)+1) = xxx

  4. #4
    Membre éclairé
    Inscrit en
    Octobre 2005
    Messages
    908
    Détails du profil
    Informations forums :
    Inscription : Octobre 2005
    Messages : 908
    Par défaut


    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
    Dim tableau() As Long
     
    Sub s()
        f
        f
        f
        f
    End Sub
     
    Function f()
        Dim nb As Integer
        nb = UBound(tableau)
     
        ReDim Preserve tableau(nb + 1)
        tableau(nb) = "truc"
     
    End Function
    affiche le message d'erreur à l'exécution de Comment faire en sorte, qu'au PREMIER passage, nb = 0 ? au second nb = 1 ... etc ?

  5. #5
    Membre Expert
    Homme Profil pro
    Développeur VBA Access
    Inscrit en
    Avril 2006
    Messages
    1 109
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur VBA Access

    Informations forums :
    Inscription : Avril 2006
    Messages : 1 109
    Par défaut
    Essaie en définissant le tableau avant le premier appel à la fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim tableau() As Long
    Sub s()
     reDim Tableau(0)
        f
    End Sub

  6. #6
    Expert confirmé Avatar de casefayere
    Homme Profil pro
    RETRAITE
    Inscrit en
    Décembre 2006
    Messages
    5 138
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Ardennes (Champagne Ardenne)

    Informations professionnelles :
    Activité : RETRAITE
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Décembre 2006
    Messages : 5 138
    Par défaut
    je pensais quelque chose comme ça, en gardant le raisonnement de Tchupacabra
    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
    Dim tableau() As Long
    Public nb As Integer
     
    Sub s()
        f
        f
        f
        f
    End Sub
     
    Function f()
        nb = nb + 1
        ReDim Preserve tableau(nb)
        tableau(nb) = "truc"
     
    End Function
    mais pas testé

    bonne soirée
    Cordialement,
    Dom
    _____________________________________________
    Vous êtes nouveau ? pour baliser votre code, cliquer sur cet exemple : Anomaly
    pensez à cliquer sur :resolu: si votre problème l'est
    Par contre, il est désagréable de voir une discussion résolue sans message final du demandeur (satisfaction, désarroi, remerciement, conclusion...)

Discussions similaires

  1. Boucler sur un tableau Ubound
    Par awa123 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 15/12/2013, 10h13
  2. Tableau / UBound
    Par pythagore3_14 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 27/08/2008, 11h30
  3. ptite info sur ubound ou plutot un tableau
    Par lionhigh dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 16/07/2008, 08h55
  4. UBound et tableau vide
    Par benoit70 dans le forum VB 6 et antérieur
    Réponses: 8
    Dernier message: 23/09/2005, 22h26
  5. Réponses: 4
    Dernier message: 13/05/2002, 16h43

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