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 :

VBA - Msg de pbs de mémoire [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre régulier
    Homme Profil pro
    Responsable Relations Client
    Inscrit en
    Mai 2017
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Responsable Relations Client
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2017
    Messages : 6
    Par défaut VBA - Msg de pbs de mémoire
    Bonsoir à tous,

    Je viens de créer une matrice pour automatiser un traitement, mais au lancement du code VBA, j'ai un message "Mémoire insuffisante". Je pense qu'il doit y avoir un loupé avec ma boucle mais je ne vois pas lequel.

    J'aurais besoin de votre aide pour y voir plus clair.

    J'explique le fonctionnement de la boucle :

    Il s'agit de vérifié si une ligne (Onglet S) se retrouve de manière identique dans l'onglet S-1 (il faut que la macro regarde si la plage A1:F1, si elle existe quelque part dans l'onglet S-1)

    Merci par avance de votre aide et bonne soirée

    Mon code ci-dessous (étant débutant en VBA, il est très basique)

    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
    Sub Compilation()
     
    Dim ODATA As Worksheet 'Onglet Data
    Dim OS As Worksheet 'Onglet S
    Dim OS1 As Worksheet 'Onglet S-1
    Dim Plage1 As Range
    Dim nb As Integer
    Dim Plage2 As Range
    Dim nb2 As Integer
    Dim i As Integer 'Cas1 copie
    Dim j As Integer 'Cas2 copie
    Dim k As Integer 'Cas3 copie
    Dim l As Integer
    Dim m As Integer
     
    'calcul nb de ligne dans l'onglet S
    Set OS = Worksheets("S")
    Set Plage1 = OS.Range("A1").CurrentRegion
    nb = Plage1.Rows.Count
     
    'calcul nb de ligne dans l'onglet S-1
    Set OS1 = Worksheets("S-1")
    Set Plage2 = OS1.Range("A1").CurrentRegion
    nb2 = Plage2.Rows.Count
     
    'compteur initiaux pour copie
    i = 5
    j = 5
    k = 5
     
    Set ODATA = Worksheets("Data")
     
    For l = 1 To nb
    For m = 1 To nb2
     
    If OS.Range("Al:Fl") = OS1.Range("Am:Fm") Then
        If Range("El") = "Type2" And Date - Range("Cl") > 21 Then
            Set copy1 = ODATA.Range("Hj")
            OS.Range("Al").Copy copy1
            Set copy2 = ODATA.Range("Ij")
            OS.Range("El").Copy copy2
            j = j + 1
     
            Else
             If Range("El") = "Type3" And Date < Range("Fl") Or Range("Fl") = "" Then
                Set copy1 = ODATA.Range("Mk")
                OS.Range("Al").Copy copy1
                Set copy2 = ODATA.Range("Nk")
                OS.Range("El").Copy copy2
                k = k + 1
                Else
                Set copy1 = ODATA.Range("Ci")
                OS.Range("Al").Copy copy1
                Set copy2 = ODATA.Range("Di")
                OS.Range("El").Copy copy2
                i = i + 1
            End If
     
        End If
     
    End If
     
    Next m
    Next l
    End Sub
    Fichiers attachés Fichiers attachés

  2. #2
    Membre Expert Avatar de jerome.vaussenat
    Homme Profil pro
    Formateur Bureautique
    Inscrit en
    Janvier 2011
    Messages
    1 629
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Formateur Bureautique
    Secteur : Enseignement

    Informations forums :
    Inscription : Janvier 2011
    Messages : 1 629
    Par défaut
    Salut,

    une première analyse me fait penser qu'il y a un problème de "" et de variables
    tu mets
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If OS.Range("Al:Fl") = OS1.Range("Am:Fm") Then
    où je metrais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If OS.Range("A" & l & ":F" & l) = OS1.Range("A" & m & ":F" & m) Then
    de cette manière VBA est bien capable de reconnaître la présence des variables.

    Après je ne suis pas sûr que cette syntaxe (du if) puisse vraiment être utiliseée pour vérifier que tous les éléments des 2 lignes sont bien identiques (c'est bien çà ?)

    Bien sûr, comme tu as été cohérent, le pb de "" est à corriger sur tout le code ...

  3. #3
    Membre régulier
    Homme Profil pro
    Responsable Relations Client
    Inscrit en
    Mai 2017
    Messages
    6
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Responsable Relations Client
    Secteur : Distribution

    Informations forums :
    Inscription : Mai 2017
    Messages : 6
    Par défaut
    Bonsoir Jérôme,

    Merci pour l'aide, j'ai remplacer l'ensemble des éléments et rajouter avant ce cycle un concaténation (mis en colonne G) pour la comparaison et ça marche 👍

    Merci encore, bonne soirée

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

Discussions similaires

  1. Validité d'un code VBA+SQL pour gestion de mémoire
    Par stefposs dans le forum VBA Access
    Réponses: 2
    Dernier message: 27/09/2007, 13h32
  2. [VBA-E] Gestion de la mémoire
    Par spileo dans le forum Macros et VBA Excel
    Réponses: 11
    Dernier message: 26/04/2007, 13h14
  3. Réponses: 7
    Dernier message: 06/06/2006, 15h38
  4. [VBA-E]QueryTable et utilisation mémoire
    Par Pgs dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 03/04/2006, 09h19
  5. [VBA-E] Saturation de la mémoire car trop de macros activées
    Par MrYoYo dans le forum Macros et VBA Excel
    Réponses: 10
    Dernier message: 02/12/2005, 19h01

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