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 :

Fonction Private sub


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    304
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 304
    Par défaut Fonction Private sub
    Bonjour,

    j'utilise un protocole :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Private Sub Worksheet_change(ByVal target As Range)
    dans une feuille, par contre, j'aimerai savoir si on peut exclure des lignes de ce protocole, pour par exemple, ne pas mettre à jour la ligne de titre à la suite d'une mauvaise manipulation.

    par avance merci.

  2. #2
    Expert confirmé
    Avatar de kiki29
    Homme Profil pro
    ex Observeur CGG / Analyste prog.
    Inscrit en
    Juin 2006
    Messages
    6 132
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Finistère (Bretagne)

    Informations professionnelles :
    Activité : ex Observeur CGG / Analyste prog.

    Informations forums :
    Inscription : Juin 2006
    Messages : 6 132
    Par défaut
    Salut, voir Les évènements dans la feuille de calcul Excel ainsi qu'une recherhce sur le forum

  3. #3
    Expert confirmé
    Avatar de Oliv-
    Homme Profil pro
    solution provider
    Inscrit en
    Mars 2006
    Messages
    4 093
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : solution provider

    Informations forums :
    Inscription : Mars 2006
    Messages : 4 093
    Billets dans le blog
    20
    Par défaut
    Salut,
    oui bien sûr, la variable target te donne la cellule (ou les) concernée
    à toi de tester

    dans cet exemple je teste chaque colonne du TARGET pour ensuite appliquer une couleur selon la taille des données (comparées à une feuille "FORMAT")
    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 Worksheet_Change(ByVal Target As Range)
     
        For Each colonne In Target.Columns
        If colonne.Column < 32 Then
        CLength = Worksheets("FORMATS").Cells(3, colonne.Column)
     
            Intersect(Target, colonne).Characters(Start:=1, Length:=CLength).Font.Color = RGB(0, 255, 0)
            Intersect(Target, colonne).Characters(Start:=CLength + 1, Length:=100).Font.Color = 0
        End If
        Next colonne
     
    End Sub
    ps : il peut être très important de vérifier avant toute action le nombre de cellules impactées par TARGET ex copié/collé sur toute une feuille !!
    Have a nice day. Oliv'
    Votre réponse est peut être dans mon blog !
    https://www.developpez.net/forums/blogs/191381-oliv-/

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Mars 2007
    Messages
    304
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2007
    Messages : 304
    Par défaut
    j'ai :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Worksheet_change(ByVal target As Range)
    If target.Count = 1 Then
        Application.EnableEvents = False
        On Error Resume Next
        If target.Column = 1 Then
            If target.Column = 6 And target.Rows <> 1 And target.Rows <> 2 Then
    est ce que target.Rows <> 1 And target.Rows <> 2 peut m'exclure les deux premières lignes de ma feuille pour une saisie malheureuse sur ces lignes ?

  5. #5
    Expert confirmé
    Avatar de Didier Gonard
    Homme Profil pro
    Formateur Office et développeur VBA en freelance
    Inscrit en
    Février 2008
    Messages
    2 805
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Formateur Office et développeur VBA en freelance

    Informations forums :
    Inscription : Février 2008
    Messages : 2 805
    Par défaut
    Bonjour,

    @meumeu73.1, pour ne pas te perdre dans tout ça :

    Change le titre de ton fil : " Fonction Private sub", en "Procédure Private Sub Worksheet_change" ou mieux " "Procédure évènementielle Private Sub Worksheet_change"

    car, tu l'auras compris maintenant, ce que tu évoques n'est pas une fonction cf le lien fourni par Kiki29, vois aussi ce tuto court :

    Par J-M Rabilloud
    Programmer efficacement avec Excel en VBA http://bidou.developpez.com/tutoriels/ExcelVBA/
    44 pages :

    cordialement,

    Didier

  6. #6
    Expert confirmé
    Avatar de Oliv-
    Homme Profil pro
    solution provider
    Inscrit en
    Mars 2006
    Messages
    4 093
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : solution provider

    Informations forums :
    Inscription : Mars 2006
    Messages : 4 093
    Billets dans le blog
    20
    Par défaut
    Citation Envoyé par meumeu73.1 Voir le message
    j'ai :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Worksheet_change(ByVal target As Range)
    If target.Count = 1 Then
        Application.EnableEvents = False
        On Error Resume Next
        If target.Column = 1 Then
            If target.Column = 6 And target.Rows <> 1 And target.Rows <> 2 Then
    est ce que target.Rows <> 1 And target.Rows <> 2 peut m'exclure les deux premières lignes de ma feuille pour une saisie malheureuse sur ces lignes ?

    Oui tu peux aussi mettre
    Have a nice day. Oliv'
    Votre réponse est peut être dans mon blog !
    https://www.developpez.net/forums/blogs/191381-oliv-/

Discussions similaires

  1. Réponses: 8
    Dernier message: 10/10/2014, 14h01
  2. [VBA] Goto faisant référence en-dehors d'un Private Sub?
    Par Oceliane dans le forum VBA Access
    Réponses: 2
    Dernier message: 28/03/2007, 15h57
  3. Réponses: 9
    Dernier message: 06/06/2006, 22h05
  4. mettre plusieurs private sub sur un bouton ?
    Par juju33 dans le forum Access
    Réponses: 2
    Dernier message: 26/03/2006, 16h22
  5. fonction et sub lors d'un meme evenement
    Par jph86 dans le forum Access
    Réponses: 6
    Dernier message: 08/03/2006, 12h02

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