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 :

Mémoire Insuffisante pour une macro simple


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut Mémoire Insuffisante pour une macro simple
    Bonjour

    J'utilise la macro suivante pour "nettoyer" le contenu de mes cellules (qui contiennent plus de 255 caractères pour info, moins de 50 cellules à traiter):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    Sub Macro1()
    Sheets("N3").Select
    Dim lastline_N3 As Long
    lastline_N3 = Range("E9").End(xlDown).Row
    Range("E4:E" & lastline_N3).Select
        For Each Cellule In Range("E4:E" & lastline_N3)
           old_text_N3 = Cellule.Value
           new_text_N3 = Replace(old_text_N3, Chr(13), Chr(10)) 
           Cellule.Value = new_text_N3   ' <-- ICI
        Next
    End Sub
    J'obtiens lors de l'exécution de la macro un message mémoire insuffisante, si je clique sur débogage, la ligne spécifiée par le debuggeur est celle en gras.
    Y aurait il un moyen de palier à ce problème ?

    Je travaille sous Excel 2003 SP1 (pc du boulot)

    D'avance merci.

    @+

    ted

  2. #2
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 553
    Points : 566
    Points
    566
    Par défaut
    j'ai déjà eu ce genre de souci

    la seule solution que j'ai trouvé est d'exporter mes macros et de les réimporter dans un nouveau fichier

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Ok mais tu l'avais fait uniquement pour la macro qui posait problème ou pour chaque macro du classeur?

  4. #4
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 553
    Points : 566
    Points
    566
    Par défaut
    j'avais tout exporter et récréer un nouveau fichier avec les mêmes données

    c'est comme si tu repartais de 0

  5. #5
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Âge : 61
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 563
    Points : 1 691
    Points
    1 691
    Par défaut
    essaye déja avec une syntaxe plus simple. même si la tienne est juste, elle fait beaucoup trop d'opération
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    Sub Macro1()
        For Each Cellule In Range("E4:E" & Range("E9").End(xlDown).Row)
           Cellule.Value = Replace(Cellule.Value, Chr(13), Chr(10))
        Next
    End Sub
    il y a aussi la possibilité qu'une macro automatique vienne perturber le déroulement de la tienne. tu ne dis pas ou en est le déroulement au momment du bug, c'est a dire a quelle occurence de cellule.

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Merci pour cette proposition qui malheureusement ne résout pas le problème...
    La macro plante sur la 3ème cellule...

  7. #7
    Membre éprouvé
    Avatar de JackOuYA
    Inscrit en
    Juin 2008
    Messages
    1 040
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 1 040
    Points : 1 191
    Points
    1 191
    Par défaut
    vérifie cela :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    msgbox Range("E9").End(xlDown).Row

  8. #8
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 537
    Points
    5 537
    Par défaut
    Bonjour,

    Question probablement inutile (mais on ne sait jamais) :

    Es-tu certain de ce qu'ailleurs dans ton code tu n'appelles-pas cette macro en provoquant une/des référence(s) circulaire(s) (sur un évènement change, par exemple) ?

  9. #9
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Citation Envoyé par JackOuYA Voir le message
    vérifie cela :


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    msgbox Range("E9").End(xlDown).Row
    C'est déjà fait, tu penses...Et ca me donne bien le rang de la derniere ligne valorisé de la colonne E, à partir de E9 (53 pour info)...


    Question probablement inutile (mais on ne sait jamais) :
    Aucune question n'est inutile

    Es-tu certain de ce qu'ailleurs dans ton code tu n'appelles-pas cette macro en provoquant une/des référence(s) circulaire(s) (sur un évènement change, par exemple) ?
    Oui...D'ailleurs, j'ai essayé d'isolé la macro dans un module (où il n'y a que le bout de code VB stipulé ici) et ca me provoque la meme erreur!

    Plus ca va et plus je me dis que c'est intrinsèque à Excel...Peut etre aussi du au fait que la cellule contient plus de 1500 caractères...

  10. #10
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Points : 5 537
    Points
    5 537
    Par défaut
    Citation Envoyé par ted the Ors Voir le message
    Oui...D'ailleurs, j'ai essayé d'isolé la macro dans un module (où il n'y a que le bout de code VB stipulé ici) et ca me provoque la meme erreur!
    isoler la macro dans un module ne l'empêche pas de s'exécuter lorsqu'on l'appelle ...

    Je repose donc ma question de manière différente :
    1) elle est appelée lors de quel évènement ?
    2) cet évènement est-il le seul cas d'appel de cette macro ?

  11. #11
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Citation Envoyé par ucfoutu Voir le message
    isoler la macro dans un module ne l'empêche pas de s'exécuter lorsqu'on l'appelle ...
    Ah c'est noté!
    Je repose donc ma question de manière différente :
    1) elle est appelée lors de quel évènement ?
    2) cet évènement est-il le seul cas d'appel de cette macro ?
    Elle est appelé uniquement via l'executeur de macro, absoluement pas sur un evenement spécifique...
    Donc:
    1) aucun...
    2) sans objet !

  12. #12
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Pour info, je viens de tester le code sur 50 cellules avec pour chaque cellule, 5000 caractères et 1000 chr(13) à remplacer.

    Tout se réalise en une fraction de seconde sans problème de mémoire.

    Peux-tu joindre ton fichier, que je fasse un test dessus ?
    .

  13. #13
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Malheureusement non dans la mesure où il contient des données professionnelles...
    Petites question: les caractères dans ta cellule sont ils précédés d'un " ' "?

  14. #14
    Membre confirmé
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    553
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 553
    Points : 566
    Points
    566
    Par défaut
    Moi je dis tout simplement que ton fichier Excel est verrolé

    Essaie ce que je te disais
    Ouvre un nouveau fichierExcel tout neuf, mets y toutes tes données et remets y tes macros

  15. #15
    Expert éminent
    Avatar de fring
    Homme Profil pro
    Engineering
    Inscrit en
    Février 2008
    Messages
    3 900
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 61
    Localisation : Belgique

    Informations professionnelles :
    Activité : Engineering

    Informations forums :
    Inscription : Février 2008
    Messages : 3 900
    Points : 7 964
    Points
    7 964
    Par défaut
    Citation Envoyé par ted the Ors Voir le message
    Petites question: les caractères dans ta cellule sont ils précédés d'un " ' "?
    euuh non mais je ne vois pas ce que ça change

    Comme le dis helios, il doit ya avoir un stuut

    A tout hazard, as-tu essayé en supprimant la ligne qui fait couiner ?

  16. #16
    Membre expérimenté
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 563
    Détails du profil
    Informations personnelles :
    Âge : 61
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 563
    Points : 1 691
    Points
    1 691
    Par défaut
    et si tu déplace cette fameuse troisieme cellule, es ce que le probleme se retrouve a la meme place ou encore sur la meme cellyule ? il y a peut etre trop d'espace dans celle la pour la fonction replace quoique a priori, ce ne soit pas limité

  17. #17
    Membre expert
    Avatar de s.n.a.f.u
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2006
    Messages
    2 760
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Août 2006
    Messages : 2 760
    Points : 3 545
    Points
    3 545
    Par défaut
    Pour savoir si cela vient du contenu de la cellule, tu peux dans un premier temps le tronquer :

    Code VBA : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Macro1()
        Sheets("N3").Select
        Dim lastline_N3 As Long
        lastline_N3 = Range("E9").End(xlDown).Row
        For Each Cellule In Range("E4:E" & lastline_N3)
           old_text_N3 = Cellule.Value
           new_text_N3 = Replace(old_text_N3, Chr(13), Chr(10)) 
           Cellule.Value = Left(new_text_N3, 255)
        Next
    End Sub

  18. #18
    Membre habitué
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    278
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Juillet 2006
    Messages : 278
    Points : 132
    Points
    132
    Par défaut
    Citation Envoyé par jml94 Voir le message
    Pour savoir si cela vient du contenu de la cellule, tu peux dans un premier temps le tronquer :

    Code VBA : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Sub Macro1()
        Sheets("N3").Select
        Dim lastline_N3 As Long
        lastline_N3 = Range("E9").End(xlDown).Row
        For Each Cellule In Range("E4:E" & lastline_N3)
           old_text_N3 = Cellule.Value
           new_text_N3 = Replace(old_text_N3, Chr(13), Chr(10)) 
           Cellule.Value = Left(new_text_N3, 255)
        Next
    End Sub
    On tient une piste ...En effet, cela a très bien fonctionné avec une troncature à 255...Une petite recherche par dichotomie montre que la limite est de 1024 charactères...A 1025: anomalie (mémoire insuffisante etc...)!

    Donc je ne sais pas quelle est l'explication "rationnelle" derriere tout cela.


    Comme le dis helios, il doit ya avoir un stuut
    Kezako?

    [EDIT] Ok, je ne suis pas doué en belgicisme, il s'agit d'un imprévu donc...

    et si tu déplace cette fameuse troisieme cellule, es ce que le probleme se retrouve a la meme place ou encore sur la meme cellyule ? il y a peut etre trop d'espace dans celle la pour la fonction replace quoique a priori, ce ne soit pas limité
    Ca ne change rien...


    Bref, en attendant, je vais "déconcatener" le contenu de chaque cellule dans 2 cellules, appliquer la macro, et reconcatener...C'est pas terrible terrible mais c'est mieux que rien...

Discussions similaires

  1. mémoire insuffisante pour charger une image
    Par benj63 dans le forum C++Builder
    Réponses: 3
    Dernier message: 07/11/2007, 18h22
  2. [vba-E] pour une macro executable automatiquement
    Par ricachu dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 10/07/2006, 11h34
  3. [excel] bouton pour une macro
    Par arcane dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 02/05/2006, 09h17
  4. [VBA] Excell : demande d'aide pour une macro
    Par Fealendril dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 11/01/2006, 16h28
  5. le meilleur SGBD pour une application simple
    Par nousss77 dans le forum Décisions SGBD
    Réponses: 3
    Dernier message: 23/09/2005, 07h45

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