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 :

Out of range [XL-2010]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Janvier 2010
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 84
    Par défaut Out of range
    Bonjour le forum

    je sens que c'est tout bête, mais je ne vois pas

    ma macro tombe en erreur "subscript out of range".

    voici l'extrait de code qui plante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    Dim MonthList() As String
    h = CStr(Year(Now())) + "-0" + CStr(X) ' qd l'erreur est rencontré, le résultat dans h="2013-02"
    MonthList(k) = h ' et k=0
    je dois louper qqc dans la syntaxe, mais je ne vois pas.

    par avance merci pour votre aide

    Ci-dessous, la macro en entier pour info:
    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
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
     
    Sub FilterMonthly()
    '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
    ' Display only the required number of months for the Pivottables
    '''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
     
    'Set the end date and start date for the display
     
        'the last completed month to be considered as the end
        Dim LastCompletedMonth As String
        LastCompletedMonth = Right(Range("LastCompletedMonth").value, 2)
     
        Dim LastMonth As Integer
        LastMonth = CInt(LastCompletedMonth)
     
        Dim RequiredNbr As Integer
    ' will be a variable later
        RequiredNbr = 3
        RequiredNbr = RequiredNbr - 1
     
     
        'calculate the list of month to be displayed
        Dim MonthList() As String
        Dim PositiveMonth() As String
        Dim NegativeMonth() As String
     
        MaxPositiveMonth = LastMonth - 1
        MaxNegativeMonth = LastMonth - RequiredNbr
     
        'Check if there is months from the previous year
        If MaxNegativeMonth <= 0 Then
     
            For i = 0 To MaxPositiveMonth
                Y = i + 1
                If Y < 10 Then
                    PositiveMonth(i) = CStr(Year(Now())) + "-0" + CStr(Y)
                Else
                    PositiveMonth(i) = CStr(Year(Now())) + "-" + CStr(Y)
                End If
            Next
     
            For j = 0 To Abs(MaxNegativeMonth)
                Z = 12 - j
                If Z < 10 Then
                    NegativeMonth(j) = CStr(Year(Now()) - 1) + "-0" + CStr(Z)
                Else
                    NegativeMonth(j) = CStr(Year(Now()) - 1) + "-" + CStr(Z)
                End If
            Next
     
     
            For l = 0 To UBound(PositiveMonth)
                MonthList(l) = PositiveMonth(l)
            Next
            For m = UBound(PositiveMonth) + 1 To UBound(PositiveMonth) + UBound(NegativeMonth)
                MonthList(m) = NegativeMonth(m)
            Next
     
        Else
        'all months are from the current year
            For k = 0 To RequiredNbr
                X = k + MaxNegativeMonth
                If X < 10 Then
                    h = CStr(Year(Now())) + "-0" + CStr(X)
                    MonthList(k) = h
                Else
                    MonthList(k) = CStr(Year(Now())) + "-" + CStr(X)
                End If
            Next
     
        End If
     
        Dim Result As String
        For b = 0 To UBound(MonthList)
            Result = Result + MonthList(b)
        Next
     
        Sheets("AT").Select
        Range("N14").Select
        ActiveCell.FormulaR1C1 = Result
     
    ''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
    'List of Pivot tables to be updated for Incoming section
     
    '    Sheets("AT").Select
     
    '    Dim listptinc As Variant
    '    listptinc = Array("M-I-0", "M-I-2", "M-I-3", "M-I-4", "M-I-5", "M-I-6")
     
    '    For j = 0 To UBound(listptinc)
    '        With ActiveSheet.PivotTables(listptinc(j)).PivotFields("Creation Month")
    '            .PivotItems(OldMonthToBeRemoved).visible = False
    '            .PivotItems(NewMonthToBeDisplayed).visible = True
    '        End With
    '    Next
     
    End Sub

  2. #2
    Membre extrêmement actif
    Avatar de NVCfrm
    Homme Profil pro
    Administrateur Système/Réseaux - Developpeur - Consultant
    Inscrit en
    Décembre 2012
    Messages
    1 037
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Autre

    Informations professionnelles :
    Activité : Administrateur Système/Réseaux - Developpeur - Consultant
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Décembre 2012
    Messages : 1 037
    Billets dans le blog
    5
    Par défaut
    bonsoir,

    commence par changer le caractère de concaténation utilisé: "+" par &.

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2010
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 84
    Par défaut
    Merci, mais pas mieux

  4. #4
    Membre Expert
    Homme Profil pro
    Retraité
    Inscrit en
    Avril 2011
    Messages
    1 858
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Avril 2011
    Messages : 1 858
    Par défaut
    Bonjour,

    Lorsque tu utilises un tableau dynamique, tu dois préciser le nombre d’éléments, les dimensions et éventuellement les limites de chaque dimension avec l'instruction ReDim.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Test()
    Dim MonthList() As String 'Tableau dynamique
    Dim X As Integer, k As Integer
        X = 2
        k = 0
        'Redéfinit la taille du tableau
        ReDim MonthList(0 To 1) '2 éléments, 1 dimension
        h = CStr(Year(Now())) + "-0" + CStr(X)
        MonthList(k) = h
    End Sub
    Cordialement.

  5. #5
    Membre confirmé
    Inscrit en
    Janvier 2010
    Messages
    84
    Détails du profil
    Informations forums :
    Inscription : Janvier 2010
    Messages : 84
    Par défaut
    Super merci, ca fonctionne.

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

Discussions similaires

  1. [VBA-E][access]"date out of range"
    Par borisa dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 27/03/2006, 17h06
  2. Réponses: 16
    Dernier message: 12/01/2006, 16h14
  3. [C#] erreur selectetedindex out of range datagrid
    Par mahboub dans le forum ASP.NET
    Réponses: 7
    Dernier message: 31/10/2005, 17h31
  4. Réponses: 10
    Dernier message: 21/09/2004, 16h44
  5. datetime data type resulted in an out-of-range
    Par faamugol dans le forum ASP
    Réponses: 2
    Dernier message: 26/05/2004, 20h51

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