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 :

Surbrillance cellule VBA


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre actif
    Homme Profil pro
    Analyse système
    Inscrit en
    Septembre 2017
    Messages
    47
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Corrèze (Limousin)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Septembre 2017
    Messages : 47
    Par défaut Surbrillance cellule VBA
    Bonjour,

    Je voudrais rendre autonome mon Excel en fonction du tableau "t_roulement_2022" et "t_abscence_2022".

    Dans un premier temps, je voudrais que quand dans le tableau absence je rentre un nom ainsi qu'une date de départ et une date de retour, la ou les cellules se mette en surbrillance d'une couleur lambda. (le plus serait d'attribuer une couleur par personne pour avoir une légende derrière).

    Pour l'instant j'arrive à gérer à l'aide d'un script vba la détection absence dans mon tableau roulement.

    Je vous transmets moi excel avec ce message.

    Merci de votre aide !

    Roulement tuto.xlsm

  2. #2
    Expert confirmé
    Homme Profil pro
    retraité
    Inscrit en
    Juin 2012
    Messages
    3 419
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : retraité
    Secteur : Associations - ONG

    Informations forums :
    Inscription : Juin 2012
    Messages : 3 419
    Par défaut
    Bonjour,

    Juste pour avancer, une façon de faire ne correspondant pas tout à fait à ce qui vous demandez, mais qui pourrait vous donner l'une ou l'autre idée:
    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
    Option Explicit
     
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
        Dim rDate As Range, kR As Long, kCdu As Long, kCNom As Long, kCAbsent As Long, sNom As String
        If Target.Count > 1 Then Exit Sub
        If Intersect(Target, Range("t_roulement")) Is Nothing Then
            '--- rien, hors tableau t_roulement
        Else
            Range("A1") = Range("B" & Target.Row)
            Set rDate = Range("t_abscence[[DU]]").Find(Cells(Target.Row, 2).Value, , , xlWhole)
            If rDate Is Nothing Then
                '--- rien
            Else
                MsgBox "absence de " & rDate.Offset(0, -1) & " à partir du " & Format(rDate, "dd.mm.yyyy")
            End If
            Set rDate = Nothing
        End If
        If Intersect(Target, Range("t_abscence")) Is Nothing Then
            '--- rien, hors tableau t_absence
        Else
            kCdu = Range("t_abscence[[DU]]").Column
            kCNom = Range("t_abscence[[Nom]]").Column
            kR = Target.Row
            sNom = Cells(kR, kCNom)
            If IsDate(Cells(kR, kCdu)) And Len(sNom) > 0 Then
                Set rDate = Range("t_roulement[[Du]]").Find(CDate(Cells(kR, kCdu)), , xlValues, xlWhole)
                If rDate Is Nothing Then
                    MsgBox "Anomalie: date " & Cells(kR, kCdu) & " non trouvée dans le tableau des roulements", , "Pour info"
                Else
                    kCAbsent = Range("t_roulement[[Absents]]").Column
                    If Cells(rDate.Row, kCAbsent) = "" Then
                        Cells(rDate.Row, kCAbsent) = sNom
                    Else
                        If InStr(Cells(rDate.Row, kCAbsent), sNom) > 0 Then
                            '--- rien, déjà inscrit
                        Else
                            Cells(rDate.Row, kCAbsent) = Cells(rDate.Row, kCAbsent) & "; " & sNom
                        End If
                        kCNom = Range("t_roulement[[" & sNom & "]]").Column
                        Cells(rDate.Row, kCNom) = "a"
                    End If
                End If
                Set rDate = Nothing
            End If
        End If
    End Sub
    Cordialement.
    Fichiers attachés Fichiers attachés

Discussions similaires

  1. [Toutes versions] Modifier cellules VBA
    Par vannily dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 11/02/2011, 13h48
  2. Selection cellules vba
    Par iperkut dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 13/04/2010, 19h31
  3. recuperer la couleur d'une cellule VBA
    Par fernier dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 16/07/2008, 11h46
  4. Verrouillages des cellules VBA
    Par peofofo dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 04/07/2008, 10h40
  5. Fusionner cellules VBA
    Par Go_Ahead dans le forum Macros et VBA Excel
    Réponses: 21
    Dernier message: 19/05/2008, 13h37

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