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-E] Problème avec Cells.Clear


Sujet :

Macros et VBA Excel

  1. #1
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut [VBA-E] Problème avec Cells.Clear
    Bonjour,

    J'ai un souci avec la commande Cells.Clear, utilisée en début de code pour "réinitialiser" une feuille
    Le code suivant est déclenché à partir d'un cmdbutton dans la sheets(1)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Sheets(1).Unprotect
    Sheets(2).Cells(1, 1).Activate
    Cells.Clear
    Cells.Font.Size = 12
    De temps en temps (et pas tout le temps), le code se lance et s'arrête après l'exécution de la commande Cells.Clear

    Je n'ai pas réussi à trouver quelles étaient les conditions pour que ça plante.
    Quelqu'un aurait une idée, ou bien a déjà été confronté à ce problème ?

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour Cwain,

    A toutes fins utiles :
    Est-ce quela tient à la version d'Excel (j'utilise Office 2000).

    Ce code fonctionne sans problème, mais la sélection doit être faite sous la forme d'une plage même pour une seule cellule : Range(Cells(1, 1)).Select ne serait pas accepté).

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sheets(2).Activate
    Range(Cells(1, 1), Cells(1, 1)).Select
    Selection.ClearContents
    Amicalement

  3. #3
    Membre confirmé
    Inscrit en
    Janvier 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Janvier 2006
    Messages : 103
    Par défaut
    tu ne veux pas essayer range("**").clearcontents?

  4. #4
    Expert éminent


    Profil pro
    Inscrit en
    Juin 2003
    Messages
    14 008
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2003
    Messages : 14 008
    Par défaut
    c'est bien la feuille 2 du classeur contenant la macro .. qui doit être effacée...?

    essai :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    ThisWorkbook.Sheets(2).cells.clear

  5. #5
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    jacques_jean> ma version d'Excel : 2003 avec SP2 partie de microsoft office small business edition 2003

    tangjuncn> disons que j'utilise Cells parce que la zone à effacer est variable (entre 6 et 600, 1000 etc...). Ceci dit je pense qu'avec un range de la première à la 60000ème ligne je devrais être tranquille . Je vais essayer ça

    bbil> c'est bien la Feuil2, je vais essayer de rajouter thisworkbook devant.

    à tous> Le souci c'est évidemment que c'est aléatoire. un exemple d'une tentative : je clique une fois sur mon bouton, le code s'arrête à cells.clear, je cliques une deuxième fois il passe... ???

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 567
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 567
    Par défaut
    il donne un message d'erreur quand il s'arrete?

  7. #7
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    Non, il n'y a même pas un message d'erreur !
    C'est comme si au lieu de j'avais !!
    J'en suis là, ça a buggué également au début, puis maintenant je n'arrive plus à reproduire le problème....
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sheets(1).Unprotect
    Sheets(2).Activate
    ThisWorkbook.Sheets(2).Cells.Clear

  8. #8
    Membre confirmé
    Inscrit en
    Janvier 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Janvier 2006
    Messages : 103
    Par défaut
    Citation Envoyé par cwain
    Non, il n'y a même pas un message d'erreur !
    C'est comme si au lieu de j'avais !!
    J'en suis là, ça a buggué également au début, puis maintenant je n'arrive plus à reproduire le problème....
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sheets(1).Unprotect
    Sheets(2).Activate
    ThisWorkbook.Sheets(2).Cells.Clear
    c pas un bonheur ça??
    Je ne sais + si ça s'écrit comme ça bonheur

  9. #9
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    Heu je te suis pas, là...

  10. #10
    Membre confirmé
    Inscrit en
    Janvier 2006
    Messages
    103
    Détails du profil
    Informations personnelles :
    Âge : 42

    Informations forums :
    Inscription : Janvier 2006
    Messages : 103
    Par défaut
    !!
    J'en suis là, ça a buggué également au début, puis maintenant je n'arrive plus à reproduire le problème....


    c pas un good news de ne + produire les pb

  11. #11
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    héhé ça serait que pour moi le fichier, je m'en contenterais...
    Hélas c'est pour d'autres utilisateurs que je connais et qui :
    - m'appeleront à chaque petit bug du programme => autant de temps en moins à répondre aux utilisateurs de developpez.com
    - ne voudront pas utiliser le programme si il buggue => 2 jours de travail inutile => le patron me vire => je peux plus manger => je n'ai plus la force de répondre aux utilisateurs de developpez.com

  12. #12
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Plutôt que pleurer comme une Madeleine, pas bientôt réglé, ton pb ?
    Parce que si tu ne trouves pas d'autre moyen, tu as la solution hard consistant à insérer une nouvelle feuille, à copier si nécessaire le format de la feuille à effacer et à supprimer cette sal......rie de feuille récalcitrante... qu'enfin on n'en parle plus

  13. #13
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    C'est vrai...
    une petite question au passage alors :
    si je supprime ma feuil2 et que j'en insère une autre, la nouvelle feuill a-t-elle toujours le numéro d'index 2, que je puisse continuer à l'appeler comme ça : ?

  14. #14
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    Tu veux que je fasse l'essai pour toi ?
    Bon c'est fait... Non, ça prend le nom de ActiveWorkbook.sheets.count
    Mais tu sais renommer une feuille ? Ou bien, au lieu de mettre Feuil1 dans ton code, tu instancies tes feuilles, auquel cas tu peux même raccourcir ton code en mettant FL1....

  15. #15
    Membre Expert
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    1 567
    Détails du profil
    Informations personnelles :
    Âge : 62
    Localisation : France

    Informations forums :
    Inscription : Novembre 2006
    Messages : 1 567
    Par défaut
    moi, j'utilise ça, c'est simple et ça fonctionne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sheets(1).Cells.ClearContents

  16. #16
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    J'utilise Clear car je dois également supprimer les formats, ce que ne fait pas ClearContents.

    Merci pour votre aide, j'utilise la suppression de l'ancienne feuille et la création d'une nouvelle avec les mêmes noms/références pour contourner le problème.

    Cwain

  17. #17
    Inactif  
    Avatar de ouskel'n'or
    Profil pro
    Inscrit en
    Février 2005
    Messages
    12 464
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2005
    Messages : 12 464
    Par défaut
    As-tu essayé Activesheet.Cells.delete ? 'a t'remplace toutes tes lignes par des lignes toutes neuves

  18. #18
    Membre éprouvé Avatar de cwain
    Profil pro
    Inscrit en
    Mars 2006
    Messages
    218
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2006
    Messages : 218
    Par défaut
    Non, je vais essayer ça, ce qui est juste un peu gavant dans mon histoire, c'est que vu que le problème est aléatoire (bon je sais, on ne dit pas "aléeatoire", on dit "je n'ai pas réussi à déterminer les conditions qui font que des fois ça marche, des fois non" ), je ne peux pas vraiment dire tout de suite si une solution est bonne ou pas...
    Merci pour l'aide

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

Discussions similaires

  1. [VBA-E] Problème avec des dates !
    Par yaya54 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 21/03/2006, 13h12
  2. [VBA-E] Problème avec Application.StatusBar
    Par laloune dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 04/03/2006, 16h44
  3. [VBA] [WORD] problèmes avec NUMPAGES
    Par meufeu dans le forum VBA Word
    Réponses: 9
    Dernier message: 08/08/2005, 16h24
  4. [VBA-Excel] Plagen avec Cells
    Par Damsou dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 13/01/2005, 10h49
  5. Problème avec XML.Clear dans un TXMLDocument
    Par Tardiff Jean-François dans le forum Composants VCL
    Réponses: 2
    Dernier message: 04/01/2005, 11h45

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