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 :

interdire une tres grande plage de cellule d'etre vide [XL-2003]


Sujet :

Macros et VBA Excel

  1. #1
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2013
    Messages
    238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 238
    Par défaut interdire une tres grande plage de cellule d'etre vide
    Bonjour tous !

    J'ai une énorme plage de cellule de A10 à A600 qui est sous forme de tableau donc en gros
    de A10 à A110
    de A115 à A215
    de A 220 à A320
    etc.. jusqu'à 600

    et dans toute ces cellule il y a des 0
    mais les différents utilisateurs risque de supprimer donc ce qui faussera mes calculs
    et je voudrait que si ils suppriment, alors le vide se remplace par un 0

    mais je ne sais pas trop comment faire

  2. #2
    Invité
    Invité(e)
    Par défaut
    bonjour,
    test ça
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Private Sub Worksheet_Change(ByVal Target As Range)
    If Target.Row > 9 And Target.Row < 601 And Target.Column = 1 And Trim("" & Target) = "" Then Target = 0
    End Sub
    Images attachées Images attachées  

  3. #3
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2013
    Messages
    238
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2013
    Messages : 238
    Par défaut
    Bonjour a toi et merci pour ta réponse,
    Effectivement ce que tu m'as donnée fonctionne, mais si l'utilisateur supprime une cellule par 1 cellule,
    si il supprime plusieurs alors cela me met un message d'erreur

  4. #4
    Membre Expert
    Profil pro
    Inscrit en
    Février 2007
    Messages
    2 266
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 2 266
    Par défaut
    Bonjour à tous,

    En évitant une boucle :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    Private Sub Worksheet_Change(ByVal Target As Range)
        Dim pl As Range
        Application.EnableEvents = False
        Set pl = Intersect([A10:A601], Union(Cells.SpecialCells(xlCellTypeBlanks), Cells.SpecialCells(xlCellTypeConstants, 22)))
        'à ajouter dans Union pour traiter également les formules ne renvoyant pas de nombre : , Cells.SpecialCells(xlCellTypeFormulas, 22)
        If Not pl Is Nothing Then pl = 0: Beep
        Application.EnableEvents = True
    End Sub
    Si tu as des zones qui ne doivent pas avoir 0 dans A10:610 il faudra définir la plage en conséquence.

    eric

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

Discussions similaires

  1. [XL-2007] Donner une nom à un plage de cellule en VBA
    Par thorgal1612 dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 11/04/2013, 10h21
  2. [AC-2007] Creation d'une tres grande base de données - solution viable ?
    Par bigfoot75 dans le forum Modélisation
    Réponses: 4
    Dernier message: 11/03/2010, 22h18
  3. Pallier une tres grande volumétrie
    Par GlamIS dans le forum Langage SQL
    Réponses: 5
    Dernier message: 09/08/2007, 18h30
  4. Macro en fonction d'une sélection de plage de cellules.
    Par Labiche dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 08/08/2006, 11h23
  5. decalage à gauche sur une tres grand tableau de char
    Par petitours dans le forum C++Builder
    Réponses: 10
    Dernier message: 14/07/2005, 23h40

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