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 :

Erreur d’exécution n°9 [XL-2016]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Homme Profil pro
    formateur
    Inscrit en
    Août 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : formateur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2018
    Messages : 7
    Par défaut Erreur d’exécution n°9
    Bonjour à tous,
    depuis un arret de plus de 10 ans, je me remet un peu sur VBA.
    J'ai écrit une procédure sur xl 2016 qui créer un nouveau classeur, supprime les feuilles à partir de la 3ème et renomme les feuilles 1 et 2.
    mais quand je teste, j'ai une erreur d'exécution n°9 qui se met. J'ai regardé sur le forum les indications mais celà ne marche toujours pas. Voici ma procédure:
    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
    Sub CreerClasseur()
        Dim Classeur As Workbook
        Dim i As Integer
         
        'Création d'un nouveau classeur
        Set Classeur = Application.Workbooks.Add
        
        'Suppression des feuilles à partir de la 3ème
        With Classeur
            'Désactiver les messages d'alerte d'Excel
            Application.DisplayAlerts = False
            For i = 3 To .Worksheets.Count
               .Worksheets(i).Delete
            Next i
            'Affectation des noms aux feuilles 1 et 2
            .Worksheets(1).Name = "Ventes Années 2017"
            .Worksheets(1).Name = "Ventes Années 2018"
            .SaveAs ThisWorkbook.Path & "/" & "Historique"
        End With
    
    End Sub

    et ça bloque sur ".Worksheets(i).Delete" après la 4ème ou 5ème boucle
    merci pour votre réponse et que la paix soit avec vous

  2. #2
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Porcaro Voir le message
    Bonjour,

    Il faut commencer par la fin :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i =  .Worksheets.Count To 3 Step -1
    Mais pourquoi ne pas paramétrer par défaut 2 onglets dans les options ?

  3. #3
    Expert confirmé
    Homme Profil pro
    Responsable des études
    Inscrit en
    Juillet 2014
    Messages
    2 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aude (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Responsable des études
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2014
    Messages : 2 681
    Par défaut
    Bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
           'Affectation des noms aux feuilles 1 et 2
            .Worksheets(1).Name = "Ventes Années 2017"
            .Worksheets(1).Name = "Ventes Années 2018"
    Attention erreur de copier coller tu renomme deux fois ta feuille 1

    Sinon tout à fait d'accord avec Eric KERGRESSE
    Si tu fait ta boucle dans le sens "normal" pour chaque feuille que tu supprime tu décales l'indice des feuilles suivantes (ce qui n'arrive pas en bouclant "à l'envers" ) et donc au bout d'un moment tu travailles sur des feuilles qui n'existent plus d'où l'erreur.

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    formateur
    Inscrit en
    Août 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : formateur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2018
    Messages : 7
    Par défaut
    Citation Envoyé par halaster08 Voir le message
    Bonjour,


    Attention erreur de copier coller tu renomme deux fois ta feuille 1

    Sinon tout à fait d'accord avec Eric KERGRESSE
    Si tu fait ta boucle dans le sens "normal" pour chaque feuille que tu supprime tu décales l'indice des feuilles suivantes (ce qui n'arrive pas en bouclant "à l'envers" ) et donc au bout d'un moment tu travailles sur des feuilles qui n'existent plus d'où l'erreur.
    a ok j'ai compris le pourquoi du comment.
    Mais maintenant j'ai un autre problème, la procédure ce bloque ici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
      .SaveAs ThisWorkbook.Path & "/" & "Historique"
    comment résoudre cela?
    par avance merci du coup de main

  5. #5
    Nouveau membre du Club
    Homme Profil pro
    formateur
    Inscrit en
    Août 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : formateur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2018
    Messages : 7
    Par défaut
    Citation Envoyé par Eric KERGRESSE Voir le message
    Bonjour,

    Il faut commencer par la fin :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    For i =  .Worksheets.Count To 3 Step -1
    Mais pourquoi ne pas paramétrer par défaut 2 onglets dans les options ?
    Merci pour la réponse.
    cela fonctionne très bien même si je ne comprend pas pourquoi ma procédure ne fonctionnait pas complètement.
    je ne voulait pas paramétrait le nombre de feuilles car c'était un exercice que je m'imposais.

    J'ai un autre soucis qui se pose sur ma dernière ligne , il se bloque sur : " .SaveAs ThisWorkbook.Path & "/" & "Historique""

  6. #6
    Invité
    Invité(e)
    Par défaut
    Citation Envoyé par Porcaro Voir le message
    C'est le Slash qui ne va pas. Il faut le remplacer par un antislash "\"

    Ps : Bonjour Halaster.

  7. #7
    Nouveau membre du Club
    Homme Profil pro
    formateur
    Inscrit en
    Août 2018
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Morbihan (Bretagne)

    Informations professionnelles :
    Activité : formateur
    Secteur : Enseignement

    Informations forums :
    Inscription : Août 2018
    Messages : 7
    Par défaut
    je viens d'essayer mais ça marche pas.

  8. #8
    Invité
    Invité(e)
    Par défaut Recitification
    Citation Envoyé par Porcaro Voir le message
    je viens d'essayer mais ça marche pas.
    Chez moi, ce code fonctionne :

    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
     
    Option Explicit
     
    Sub CreerClasseur()
     
        Dim Classeur As Workbook
        Dim I As Integer
     
        'Création d'un nouveau classeur
        Set Classeur = Application.Workbooks.Add
     
        'Suppression des feuilles à partir de la 3ème
        With Classeur
            'Désactiver les messages d'alerte d'Excel
            Application.DisplayAlerts = False
            If .Worksheets.Count > 2 Then
                For I = .Worksheets.Count To 3 Step -1
                   .Worksheets(I).Delete
                Next I
            End If
            'Affectation des noms aux feuilles 1 et 2
            .Worksheets(1).Name = "Ventes Années 2017"
           ' .Worksheets(2).Name = "Ventes Années 2018"
            .SaveAs ThisWorkbook.Path & "\" & "Historique"
            Application.DisplayAlerts = True
        End With
     
        Set Classeur = Nothing
     
    End Sub
    Dernière modification par Invité ; 14/08/2018 à 14h47. Motif: Reprise du code

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

Discussions similaires

  1. [AC-2007] Erreur d’exécution 94
    Par Kuky18 dans le forum VBA Access
    Réponses: 8
    Dernier message: 21/07/2011, 16h15
  2. [AC-2007] erreur d’exécution 3167
    Par rominous41 dans le forum Requêtes et SQL.
    Réponses: 4
    Dernier message: 11/05/2011, 14h39
  3. Erreur dexécution '91'
    Par VELO1222 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 27/01/2011, 17h25
  4. erreur dexécution 1004
    Par VELO1222 dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 23/01/2011, 22h29
  5. Réponses: 2
    Dernier message: 07/05/2008, 13h31

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