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 :

worksheet_change seulement lors d'une suppression [XL-2019]


Sujet :

Macros et VBA Excel

  1. #21
    Membre régulier
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Janvier 2020
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Janvier 2020
    Messages : 129
    Points : 73
    Points
    73
    Par défaut
    Bonjour à tous,
    Pour ceux qui serait intéressé, j'ai trouvé une autre méthode. Avec ces avantages et inconvénient elle aussi...
    Elle consiste à griser/rendre inopérant le bouton "supprimer" ID293 du menu qui apparait quand on fait clic droit.
    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
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
     
    Application.CommandBars.FindControl(ID:=293).Enabled = True 'remet supprimer
     
    Nosupp = WorksheetFunction.CountA(Target.Columns(1)) 'Nosupp = le nb de cellule non vide de la 1ère colonne du target
     
    End Sub
     
     Private Sub worksheet_beforerightclick(ByVal Target As Range, Cancel As Boolean)
     
     If Target.Address = Target.EntireRow.Address And Nosupp > 0 Then
     
     Application.CommandBars.FindControl(ID:=293).Enabled = False  'grise supprimer
     
     End If
     
     End Sub
    Aux conditions que :
    -sélection 1 ou plusieurs ligne complète
    -la somme des valeurs de la 1ère colonne (donc colonne A quand on sélectionne une ligne complète) soit >0. non vide

    La sélection d'une autre cellule permet de réafficher le bouton.

    Bien sûr, on peut contourner le code en supprimant la ligne via le menu "Accueil"

    J'aimerai faire de même avec le bouton "couper"...mais je n'arrive pas à trouver l'ID correspondant. Où puis je trouver ça?

    Merci
    Benoit

  2. #22
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 814
    Points : 2 949
    Points
    2 949
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Copier : ID = 29
    Couper : ID = 21
    Coller : ID = 22
    Cordialement,
    Franck

  3. #23
    Membre régulier
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Janvier 2020
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Janvier 2020
    Messages : 129
    Points : 73
    Points
    73
    Par défaut
    Bonjour Franck
    Merci pour ton retour. J'en perds mon latin...
    Pour commencer doucement, j'ai juste remplacé les 293 de mon code précédent par 21 : couper reste visible, idem avec 22 : coller reste visible. Et je ne vois pas d'autres boutons grisés
    Si je remplace par 29...ça plante ! Variable objet ou variable de bloc With non définie, ligne 2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub Worksheet_SelectionChange(ByVal Target As Range)
    Application.CommandBars.FindControl(ID:=29).Enabled = True 'remet supprimer 293
    Nosupp = WorksheetFunction.CountA(Target.Columns(1)) 'Nosupp = le nb de cellule non vide de la 1ère colonne du target
    End Sub
    C'est frustrant...
    Je suis en 2019...une influence?
    Comment trouve tu les N° ID, j'ai fouillé le net 1h sans trouvé de liste. J'avais testé 21, mais faute de résultat, j'en avais déduit que ce n'était pas le bon.

    A+

  4. #24
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 755
    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 : 12 755
    Points : 28 606
    Points
    28 606
    Billets dans le blog
    53
    Par défaut
    Bonjour,
    Bien sûr, on peut contourner le code en supprimant la ligne via le menu "Accueil"
    Ou tout simplement la combinaison Ctrl & - dans la cellule de la ligne si c'est un tableau structuré et si c'est une plage de cellules classique Ctrl & - après avoir sélectionné la ligne (Raccourci Shift & Barre d'espacement)

    J'avais prédis que ce serait une usine à gaz.

    SI vraiment il faut contrôler tout cela.
    Pourquoi ne pas bloquer simplement l'accès à la feuille en la protégeant ou en la cachant et effectuer les mises à jour par formulaire ?
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

  5. #25
    Membre émérite
    Avatar de pijaku
    Homme Profil pro
    Inscrit en
    Août 2010
    Messages
    1 814
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 50
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Août 2010
    Messages : 1 814
    Points : 2 949
    Points
    2 949
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Comme depuis le début, je rejoins Philippe...

    Pour la liste des FindControl de la CommandBars :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Sub ListeFindControlById()
    Dim i As Long, cpt As Long, strC As String
    For i = 1 To 100000
        On Error Resume Next
        strC = Application.CommandBars.FindControl(ID:=i).Caption
        If Err.Number = 0 Then
            cpt = cpt + 1
            Cells(cpt, 1) = Application.CommandBars.FindControl(ID:=i).Caption
            Cells(cpt, 2) = i
        End If
        On Error GoTo 0
    Next
    End Sub
    Macro un peu longuette...

    Ici une liste différente : https://ebooks.at.ua/forum/4-6-1
    Cordialement,
    Franck

  6. #26
    Membre régulier
    Homme Profil pro
    Ingénieur qualité méthodes
    Inscrit en
    Janvier 2020
    Messages
    129
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Seine et Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur qualité méthodes

    Informations forums :
    Inscription : Janvier 2020
    Messages : 129
    Points : 73
    Points
    73
    Par défaut
    Bonjour Messieurs,
    Merci pour votre persévérance. Qui n'a d'équivalent que mon entêtement...
    J'aimais bien cette idée de macro et comme à chaque pas, je pensais touché la solution du doigt j'ai continué dans cette voie et négligé la voie "protéger la feuille".
    Un peu aussi pcq mes précédentes expérience sur ce sujet n'avaient pas été concluante.

    Nouvelle journée...nouveau départ !
    Je viens de protéger ma feuille avec des cellules verrouillées/pas verrouillées et des autorisations adaptées et devinez quoi... c'est nickel!
    -suppression de mes fameuses lignes de titre interdite, mais je peux les masquer/afficher
    -possible de copier/coller, couper/insérer, insérer les autres lignes
    -possible de modifier les cellules, leur format etc...

    J'entends déjà Philippe dire : "je te l'avais bien dis"...
    Oui, mea culpa.
    Merci pour le temps que vous avez consacré à ce sujet. J'aurai au moins appris des choses

    Bonne journée
    Benoit

  7. #27
    Rédacteur
    Avatar de Philippe Tulliez
    Homme Profil pro
    Formateur, développeur et consultant Excel, Access, Word et VBA
    Inscrit en
    Janvier 2010
    Messages
    12 755
    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 : 12 755
    Points : 28 606
    Points
    28 606
    Billets dans le blog
    53
    Par défaut
    Bonjour Benoit,
    Sage décision.
    En fait avant de passer au VBA, il faut penser d'abord à Excel et dès que l'on programme, utiliser les méthodes utilisant les fonctionnalités d'excel et pour l'algorithme penser "Comment ferais-je cela manuellement ?" et le traduire en VBA.
    Philippe Tulliez
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément. (Nicolas Boileau)
    Lorsque vous avez la réponse à votre question, n'oubliez pas de cliquer sur et si celle-ci est pertinente pensez à voter
    Mes tutoriels : Utilisation de l'assistant « Insertion de fonction », Les filtres avancés ou élaborés dans Excel
    Mon dernier billet : Utilisation de la fonction Dir en VBA pour vérifier l'existence d'un fichier

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Message d'erreur inattendue lors d'une suppression
    Par Just-Soft dans le forum Bases de données
    Réponses: 8
    Dernier message: 18/11/2008, 11h42
  2. Réponses: 3
    Dernier message: 13/04/2008, 02h40
  3. [JDOM] Problème d'iterateur lors d'une suppression
    Par romuluslepunk dans le forum Format d'échange (XML, JSON...)
    Réponses: 3
    Dernier message: 07/01/2006, 15h00
  4. Probleme lors d'une suppression
    Par DrTank dans le forum Langage SQL
    Réponses: 5
    Dernier message: 21/04/2005, 17h38
  5. Combler les trous lors d'une suppression dans une table
    Par Billybongjoe dans le forum PostgreSQL
    Réponses: 5
    Dernier message: 08/04/2004, 14h02

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