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 :

Execution intempestive d'une fonction personnalisée au milieu d'une macro


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Femme Profil pro
    Autodidacte
    Inscrit en
    Octobre 2018
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Octobre 2018
    Messages : 4
    Par défaut Execution intempestive d'une fonction personnalisée au milieu d'une macro
    Bonjour,

    Les premières lignes de ma macro permettent de supprimer deux colonnes dans une feuille. lorsque j'exécute le pas à pas, je me rend compte que la macro change de module et se place au début d'une fonction personnalisée une fois arrivée au Clearcontents

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Dim r As Range
    Sheets("DR_Liste_Ress").Select
    Set r = Sheets("DR_Liste_Ress").Range("k:l")
    r.Select
    r.Delete
    Je désespère.. ce n'est pas la première fois que ça m'arrive et là je ne vois pas comment faire autrement

    merci par avance

  2. #2
    Expert confirmé Avatar de BENNASR
    Homme Profil pro
    Responsable comptable & financier
    Inscrit en
    Décembre 2013
    Messages
    2 974
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Responsable comptable & financier
    Secteur : Finance

    Informations forums :
    Inscription : Décembre 2013
    Messages : 2 974
    Par défaut
    bonsoir
    essayer avec :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Sub test()
    Sheets("DR_Liste_Ress").Range("K:L").Clear
    End Sub

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Autodidacte
    Inscrit en
    Octobre 2018
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Octobre 2018
    Messages : 4
    Par défaut
    Bonjour,

    merci. J'ai toujours tendance a en écrire bcp (trop).

    mais il semble que le problème ne vienne pas de ce code. partout dans mes macros, lorsque je lance le pas-à-pas, j’atterris sur un fonction personnalisée; pas toujours la même.

    merci de votre aide

  4. #4
    Expert confirmé
    Homme Profil pro
    aucune
    Inscrit en
    Avril 2016
    Messages
    7 563
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 84
    Localisation : France, Pyrénées Atlantiques (Aquitaine)

    Informations professionnelles :
    Activité : aucune

    Informations forums :
    Inscription : Avril 2016
    Messages : 7 563
    Par défaut
    Bonjour

    Il est pour le mins désespérant de lire ceci :
    je me rend compte que la macro change de module et se place au début d'une fonction personnalisée une fois arrivée au Clearcontents
    Une macro ne saurait "changer de module" !
    Le code que tu montres là n'est en soi aucunement responsable de quoi que ce soit. On peut deviner (deviner uniquement) que des cellules de ta feuille de calcul contiennent des formules qui interviennent du fait que les références qu'elles utilisent ne sont plus les mêmes après tes suppressions.

    Autre supposition : des instructions qui, dans l'évènement Change, s'exécutent lors de tes suppressions.

    La teneur de ton message ne permet pas d'aller plus loin.

  5. #5
    Membre Expert Avatar de Transitoire
    Homme Profil pro
    Auditeur informatique
    Inscrit en
    Décembre 2017
    Messages
    733
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 71
    Localisation : France, Alpes Maritimes (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Auditeur informatique

    Informations forums :
    Inscription : Décembre 2017
    Messages : 733
    Par défaut
    Bonsoir,
    Première question pour le fun, ça bouge tout seul en permanence ou juste pour "halloween"
    Bon sérieux maintenant, quel est donc le nom de la Fonction personnalisée? peut être le nom choisi interfère-t-il avec une variable ou autre chose?
    Cordialement

  6. #6
    Futur Membre du Club
    Femme Profil pro
    Autodidacte
    Inscrit en
    Octobre 2018
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 33
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Autodidacte

    Informations forums :
    Inscription : Octobre 2018
    Messages : 4
    Par défaut
    Bonsoir,

    j'aimerais que ce soit seulement pour halloween...

    voici la fonction qui "se lance":
    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
    78
    79
    80
    81
    82
    Function Ressources(i, R As Range) As String
    'affiche les fonctions (type de ressource) correspondant à chacun des trigrammes saisis dans la colonne ressources
     
    Dim nb, positionslash1, positionslash2, positionslash3 As Integer
    Dim saisie, region, R1, R2, R3, R4 As String
     
    saisie = i.Value
    region = R.Value
     
    ''''i est la cellule contenant les ressources saisies à la main + saisie est son contenu
     
    'définition du nb d'itérations / de concatenations
    If saisie = "" Then
    nb = 0
    Else
    nb = Len(saisie) - Len(Replace(saisie, "/", "")) + 1
    End If
     
    'AUCUNE ITERATION
    If nb = 0 Then
    Ressources = ""
     
    '___'1 ITERATION
        ElseIf nb = 1 Then
        'def 1ère ressource seule
        Ressources = Application.WorksheetFunction.VLookup(saisie, Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
    '_______'2 ITERATIONS
            'def 1ère ressource --- gauche("developper",3)=dev --- gauche (saisie, instr retourne l'empl du début du mot recherché - 1 SOIT le nb de car à sortir avec left)
            ElseIf nb = 2 Then
     
            R1 = Application.WorksheetFunction.VLookup(Left(saisie, InStr(1, saisie, "/") - 1) _
            , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
            'def 2ème ressource
            R2 = Application.WorksheetFunction.VLookup(Right(saisie, Len(saisie) - InStr(1, saisie, "/")) _
            , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
            Ressources = R1 & " " & R2
     
    '___________'3 ITERATIONS
                ElseIf nb = 3 Then
     
                R1 = Application.WorksheetFunction.VLookup(Left(saisie, InStr(1, saisie, "/") - 1) _
                , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                positionslash1 = InStr(saisie, "/")
                positionslash2 = InStr(positionslash1 + 1, saisie, "/")
     
                R2 = Application.WorksheetFunction.VLookup(Mid(saisie, positionslash1 + 1, positionslash2 - positionslash1 - 1) _
                , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
     
                R3 = Application.WorksheetFunction.VLookup(Right(saisie, Len(saisie) - positionslash2) _
                , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                Ressources = R1 & " " & R2 & " " & R3
     
    '_______________'4 ITERATIONS
                    ElseIf nb = 4 Then
     
                    R1 = Application.WorksheetFunction.VLookup(Left(saisie, InStr(1, saisie, "/") - 1) _
                    , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                    positionslash1 = InStr(saisie, "/")
                    positionslash2 = InStr(positionslash1 + 1, saisie, "/")
     
                    R2 = Application.WorksheetFunction.VLookup(Mid(saisie, positionslash1 + 1, positionslash2 - positionslash1 - 1) _
                    , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                    positionslash3 = InStr(positionslash2 + 1, saisie, "/")
     
                    R3 = Application.WorksheetFunction.VLookup(Mid(saisie, positionslash2 + 1, positionslash3 - positionslash2 - 1) _
                    , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                    R4 = Application.WorksheetFunction.VLookup(Right(saisie, Len(saisie) - positionslash3) _
                    , Range("tableau15[[Tri_" & region & "]:[Type_" & region & "]]"), 2, 0)
     
                    Ressources = R1 & " " & R2 & " " & R3 & " " & R4
     
    End If
    End Function

Discussions similaires

  1. Réponses: 1
    Dernier message: 12/05/2011, 12h48
  2. appel d'une fonction vb a partir d'une fonction javascript!
    Par labib23dz dans le forum Général JavaScript
    Réponses: 0
    Dernier message: 03/07/2009, 11h04
  3. faire passer une fonction entant que parametre d'une fonction
    Par gali_fr dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 29/05/2008, 15h18
  4. Réponses: 6
    Dernier message: 08/12/2007, 14h33
  5. Réponses: 14
    Dernier message: 16/05/2006, 11h26

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