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 :

Comment regrouper 2 codes VBA sur une même feuille


Sujet :

Macros et VBA Excel

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    responsable d'équipe
    Inscrit en
    Décembre 2017
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : responsable d'équipe
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2017
    Messages : 51
    Points : 38
    Points
    38
    Par défaut Comment regrouper 2 codes VBA sur une même feuille
    Bonjour

    J'ai 2 codes vba que je souhaiterais mettre sur chaque mois de mon exemple.

    * Le 1er qui n'autorise pas plus de 12 CA par jour.

    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
    Public Flag As Boolean
    Dim nCA&, nCAJ&, nCAN&, n12h&
    Private Sub Worksheet_Change(ByVal Target As Range)
        If Intersect([C9:M46], Target) Is Nothing Then Exit Sub
        nCA = Application.CountIf(Intersect([9:46], Target.EntireColumn), "CA")
        nRPM = Application.CountIf(Intersect([9:46], Target.EntireColumn), "RPM")
        nCAJ = Application.CountIf(Intersect([9:46], Target.EntireColumn), "CAJ*")
        nCAN = Application.CountIf(Intersect([9:46], Target.EntireColumn), "*CAN")
                If (nCA + nCAJ + nRPM) > 12 Or (nCA + nCAN + nRPM) > 12 Then
            MsgBox "Le nombre maximal de 12 CA total est déjà atteint !", vbCritical, "Saisie CA"
            Target.Interior.Color = RGB(255, 255, 255)
            Application.EnableEvents = False
            Target.ClearContents
            Application.EnableEvents = True
        End If
    End Sub"
     
    * Et le 2ème qui n'autorise pas plus de 5 12h par jour
     
    "Public Flag As Boolean
    Dim n12h&
    Private Sub Worksheet_Change(ByVal Target As Range)
        If Intersect([C9:M46], Target) Is Nothing Then Exit Sub
        n12h = Application.CountIf(Intersect([9:46], Target.EntireColumn), "12h")
        If n12h > 5 Then
            MsgBox "Le nombre maximal de 12h pour ce jour est déjà atteint !", vbCritical, "Saisie 12h"
            Target.Interior.Color = RGB(255, 255, 255)
            Application.EnableEvents = False
            Target.ClearContents
            Application.EnableEvents = True
        End If
    End Sub
    Dans mon exemple je ne l'ai essayé que sur le mois de décembre mais je ne sais pas comment les associer.
    Un code seul sur la page fonctionne mais comment dois-je m'y prendre pour associer les 2 codes afin qu'ils fonctionnent comme ci-dessus?

    Merci par avance
    Fichiers attachés Fichiers attachés

  2. #2
    Membre chevronné
    Inscrit en
    Septembre 2007
    Messages
    1 134
    Détails du profil
    Informations forums :
    Inscription : Septembre 2007
    Messages : 1 134
    Points : 1 808
    Points
    1 808
    Par défaut
    Bonjour,
    Citation Envoyé par manjul1 Voir le message
    mais je ne sais pas comment les associer.
    Simplement comme ceci, cela devrait fonctionner :
    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
    Private Sub Worksheet_Change(ByVal Target As Range)
    Dim nCA&, nCAJ&, nCAN&, n12h&
    Dim n12h&
     
        If Intersect([C9:M46], Target) Is Nothing Then Exit Sub
        nCA = Application.CountIf(Intersect([9:46], Target.EntireColumn), "CA")
        nRPM = Application.CountIf(Intersect([9:46], Target.EntireColumn), "RPM")
        nCAJ = Application.CountIf(Intersect([9:46], Target.EntireColumn), "CAJ*")
        nCAN = Application.CountIf(Intersect([9:46], Target.EntireColumn), "*CAN")
     
        If (nCA + nCAJ + nRPM) > 12 Or (nCA + nCAN + nRPM) > 12 Then
     
     
            MsgBox "Le nombre maximal de 12 CA total est déjà atteint !", vbCritical, "Saisie CA"
            Target.Interior.Color = RGB(255, 255, 255)
            Application.EnableEvents = False
            Target.ClearContents
            Application.EnableEvents = True
        End If
        n12h = Application.CountIf(Intersect([9:46], Target.EntireColumn), "12h")
        If n12h > 5 Then
            MsgBox "Le nombre maximal de 12h pour ce jour est déjà atteint !", vbCritical, "Saisie 12h"
            Target.Interior.Color = RGB(255, 255, 255)
            Application.EnableEvents = False
            Target.ClearContents
            Application.EnableEvents = True
        End If
    End Sub

  3. #3
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    13 014
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Formateur, développeur et consultant Excel, Access, Word et VBA

    Informations forums :
    Inscription : Janvier 2010
    Messages : 13 014
    Points : 29 083
    Points
    29 083
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Quand je lis rapidement le code que tu publies, je me demande quelle est la raison qui te pousse à passer par le VBA.
    Organise tes données dans un tableau structuré, utilise les fonctions natives d'excel et les fonctionnalités et outils natifs d'excel comme par exemple les tableaux croisés dynamiques et tu obtiendras le même résultat sans aucun problème

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    responsable d'équipe
    Inscrit en
    Décembre 2017
    Messages
    51
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : responsable d'équipe
    Secteur : Service public

    Informations forums :
    Inscription : Décembre 2017
    Messages : 51
    Points : 38
    Points
    38
    Par défaut
    Merci

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 11/02/2019, 06h10
  2. Réponses: 4
    Dernier message: 17/12/2017, 15h25
  3. Réponses: 7
    Dernier message: 04/06/2015, 12h23
  4. Deux codes JavaScript sur une même page
    Par rafafa87 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 18/06/2013, 22h35
  5. Réponses: 2
    Dernier message: 29/11/2006, 12h52

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