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 :

Message d'erreur lors de l'exécution d'une macro. depuis un menu contextuel [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut Message d'erreur lors de l'exécution d'une macro. depuis un menu contextuel
    Bonjour,

    Je viens de rajouter un item sur le menu contextuel via le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    Private Sub Workbook_Open()
     
    Sheets("PRIX").Activate
     
    Application.CommandBars("Cell").Reset
    With Application.CommandBars("Cell").Controls.Add(msoControlButton)
          .Caption = "Ajouter au devis "
          .BeginGroup = True
          .OnAction = "clic_droit"
    End With
     
    End Sub
    J'ai codé la macro. suivante :

    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
    Sub clic_droit()
     
        Dim tabCellules(), compteur As Integer
        Dim cellule As Range
        Dim b As Integer
        Dim i As Integer, j As Integer, k As Integer
        Dim rfound As Range
     
        ' Ouverture du fichier de remise de prix type
        On Error Resume Next
        Workbooks.Open Filename:="\\Serv\ode\gestion de tole\DEVIS CLIENT\remise de prix type.xls"
     
        ' stockage des lignes sélectionnées par clic-droit
        compteur = 0
     
        For Each cellule In Selection
            ReDim Preserve tabCellules(compteur)
            tabCellules(compteur) = cellule.Row
            compteur = compteur + 1
        Next cellule
     
     
        ReDim Preserve tabCellules(compteur - 1)
     
        Workbooks("remise de prix type.xls").Worksheets("Feuil1").Activate
     
        ' Recherche de "Référence" dans la colonne 'D'
        Set rfound = Worksheets("Feuil1").Range("E1:E" & .Cells(.Rows.Count, "E").End(xlUp).Row).Find("Référence", LookIn:=xlValues)
        ' Si trouvé
        If Not rfound Is Nothing Then
            i = rfound.Row
        End If
     
        ' Recherche du caractère xxxx dans la colonne 'D'
        j = 0
        Set rfound = Worksheets("Feuil1").Range("E28:E" & .Cells(.Rows.Count, "E").End(xlUp).Row).Find("xxxx", LookIn:=xlValues)
        ' Si trouvé
        If Not rfound Is Nothing Then
            j = rfound.Row
        End If
     
        ' Détermination du nombre de lignes à supprimer
        If j > i + 1 Then
     
           k = j - i - 1
     
           j = 1
           Do Until j > k
               Worksheets("Feuil1").Rows(j + i).Delete Shift:=xlUp
               j = j + 1
           Loop
     
        End If
     
        Workbooks("remise de prix type.xls").Worksheets("Feuil1").Activate
     
        ' Renseignement des différentes informations sur la feuille de remise de prix
     
     
        For j = 0 To UBound(tabCellules)
               Worksheets("Feuil1").Rows(i).Insert
     
               With Worksheets("Feuil1")
                   .Range("D" & i).Value = Workbooks("CLASSEUR CALCUL DE PRIX  2015.xls").Worksheets("Prix").Cells(tabCellules(i), 2)
                   .Range("E" & i).Value = Workbooks("CLASSEUR CALCUL DE PRIX  2015.xls").Worksheets("Prix").Cells(tabCellules(i), 3)
                   .Range("H" & i).Value = Workbooks("CLASSEUR CALCUL DE PRIX  2015.xls").Worksheets("Prix").Cells(tabCellules(i), 8)
                   .Range("J" & i).Value = Workbooks("CLASSEUR CALCUL DE PRIX  2015.xls").Worksheets("Prix").Cells(tabCellules(i), 7)
                   .Range("Q" & i).Value = Workbooks("CLASSEUR CALCUL DE PRIX  2015.xls").Worksheets("Prix").Cells(tabCellules(i), 31)
                   .Range("R" & i).FormulaR1C1 = "=RC[-1]*RC[-2]"
               End With
     
               i = i + 1
        Next j
     
     
     
    End Sub
    Lorsque j'ouvre mon classeur, j'ai bien le menu contextuel que j'ai ajouté, par contre lorsque je le lance, j'ai le message d'erreur figurant en pièce-jointe.
    Fichiers attachés Fichiers attachés

  2. #2
    Membre éprouvé Avatar de issoram
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2009
    Messages
    665
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2009
    Messages : 665
    Points : 929
    Points
    929
    Par défaut
    Bonjour,

    Où (dans quel type de module) as-tu mis la fonction clic_droit?

  3. #3
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut
    J'ai fait insertion procédure type public.

  4. #4
    Membre éprouvé Avatar de issoram
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2009
    Messages
    665
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Saône et Loire (Bourgogne)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2009
    Messages : 665
    Points : 929
    Points
    929
    Par défaut
    Ce n'était pas ma question mais pas grave...
    A mon avis ta procédure clic_droit est dans le "module" ThisWorkbook. Crée un module standard (Insertion module) et coupe/colle ta ta procédure dedans.

  5. #5
    Membre averti
    Homme Profil pro
    Inscrit en
    Novembre 2008
    Messages
    611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations forums :
    Inscription : Novembre 2008
    Messages : 611
    Points : 359
    Points
    359
    Par défaut
    Parfait merci bien !

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 07/10/2009, 11h38
  2. Réponses: 4
    Dernier message: 22/07/2009, 11h01
  3. [DI 11.7.3.4] message d'erreur lors de l'exécution d'un Job
    Par cubitus77 dans le forum Alimentation
    Réponses: 1
    Dernier message: 03/10/2008, 06h53
  4. Exécuter une macro depuis le menu contextuel du clic droit?
    Par drthodt dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 24/02/2008, 19h12
  5. [VBA-E]Message d'erreur lors de l'affectation d'une macro + prob form
    Par V3lkin dans le forum Macros et VBA Excel
    Réponses: 8
    Dernier message: 22/11/2006, 14h07

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