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

VBA Access Discussion :

Mettre un 0 dans une zone de texte sur condition


Sujet :

VBA Access

  1. #1
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut Mettre un 0 dans une zone de texte sur condition
    Bonjour,

    Mon Code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Sous_Ensemble_Click()
         If Sous_Ensemble.Text <>"430-1" Then
             Me.Commentaire_Réf.Value = "0"
             Me.Descriptif_Réf.Value = "0"
         End If
    End Sub
    Je ne vois pas pourquoi mon code ne va pas, je pense que c'est un truc tout bête.

    Cordialement,
    Bubut

  2. #2
    Membre expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Points : 3 228
    Points
    3 228
    Par défaut
    Essaie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sous_Ensemble.Value ou Sous_Ensemble
    ............................................................................................

    Dans l'intérêt de tous, ne posez pas de questions techniques par messages privés.

  3. #3
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    Mon problème est au niveau d'ici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
             Me.Commentaire_Réf.Value = "0"
             Me.Descriptif_Réf.Value = "0"

  4. #4
    Expert éminent
    Avatar de Lou Pitchoun
    Profil pro
    Inscrit en
    Février 2005
    Messages
    5 038
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2005
    Messages : 5 038
    Points : 8 268
    Points
    8 268
    Par défaut
    Salut,

    Je rejoins mout1324.
    Le problème n'est pas sur les 2 instructions qui suivent le If.

    Et puis pourquoi affecter des 0 à un champ texte ??

  5. #5
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    J'affecte des 0 car après je travail avec Excel et quand j'exporte les données d'access vers excel, Excel n'accepte pas les valeurs nuls.

    Au niveau de mon :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Sous_Ensemble.Text <>"430-1" Then
    Je suis sur que c'est bon car je travaille déjà avec cette condition et je veux rajouter :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
             Me.Commentaire_Réf.Value = "0"
             Me.Descriptif_Réf.Value = "0"
    Mais ca fonctionne pas.

    Cordialement,
    Bubut

  6. #6
    Expert éminent
    Avatar de Lou Pitchoun
    Profil pro
    Inscrit en
    Février 2005
    Messages
    5 038
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2005
    Messages : 5 038
    Points : 8 268
    Points
    8 268
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Private Sub Sous_Ensemble_Click()
         If Sous_Ensemble.Text <>"430-1" Then
    Sous_Ensemble c'est quoi ?? un bouton ?

  7. #7
    Membre expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Points : 3 228
    Points
    3 228
    Par défaut
    Citation Envoyé par Bubut
    Mais ca fonctionne pas.

    Qu'entends-tu par là? tu as un message d'erreur à la compilation ? à l'exécution? ou cela ne fait pas ce que tu souhaites?
    ............................................................................................

    Dans l'intérêt de tous, ne posez pas de questions techniques par messages privés.

  8. #8
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    Sous_Ensemble est une liste déroulante et Commentaire_Réf et Descriptif_Réf sont des zones de textes.

  9. #9
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    Non il n'y a pas de message d'erreur.
    Et il ne fait pas se que je souhaite.

  10. #10
    Expert éminent
    Avatar de Lou Pitchoun
    Profil pro
    Inscrit en
    Février 2005
    Messages
    5 038
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Février 2005
    Messages : 5 038
    Points : 8 268
    Points
    8 268
    Par défaut
    Citation Envoyé par Bubut
    Sous_Ensemble est une liste déroulante et Commentaire_Réf et Descriptif_Réf sont des zones de textes.
    On avance

    Donc tu testes la valeur de ta liste déroulante.
    Si la valeur est différente de 430-1 alors tu mets les 0.

    Si c'est ça :

    Sur l'évènement 'Sur MAJ' de la liste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    If Sous_Ensemble.Text <>"430-1" Then
             Me.Commentaire_Réf.Value = "0"
             Me.Descriptif_Réf.Value = "0"
    End If
    J'ai laissé .Text mais .Value fonctionne aussi (ce que j'utilise le plus, il faut dire...)

  11. #11
    Membre expérimenté
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Points : 1 664
    Points
    1 664
    Par défaut valeur nulle
    Bonjour,
    Excusez-moi de vouloir revenir un peu plus haut.
    Citation Envoyé par Bubut
    J'affecte des 0 car après je travail avec Excel et quand j'exporte les données d'access vers excel, Excel n'accepte pas les valeurs nuls.
    Mais pourquoi ne pas utiliser la fonction nz dans ce cas, car elle peut convertir toute valeur nulle en ... zéro (0) par exemple?
    Si c'est le seul problème ...

    Bon courage et @+
    La théorie, c'est quand on sait tout et que rien ne fonctionne. La pratique, c'est quand tout fonctionne et que personne ne sait pourquoi. Ici nous avons réuni théorie et pratique: Rien ne fonctionne ... et personne ne sait pourquoi!
    Albert Einstein

  12. #12
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    Ca ne fonctionne pas avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    If Sous_Ensemble.Text <>"430-1" Then  Me.Commentaire_Réf.Value = "0"  Me.Descriptif_Réf.Value = "0" End If
    Sur l'évènement MAJ.

    Je vais voir pour la fonction nz, si quelqu'un peut me renseigner dessus.

    Cordialement;
    Bubut

  13. #13
    Membre éclairé
    Inscrit en
    Décembre 2006
    Messages
    891
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 891
    Points : 831
    Points
    831
    Par défaut et ca...
    Je survole votre discus

    Mais une zone de texte c'est pour moi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TxtZoneTxt.Text = "Quelque chose en texte donc entre guillement"

  14. #14
    Membre expérimenté
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Points : 1 664
    Points
    1 664
    Par défaut
    Bonjour,
    Citation Envoyé par ESVBA
    Mais une zone de texte c'est pour moi
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    TxtZoneTxt.Text = "Quelque chose en texte donc entre guillement"
    Ceci est vrai dans une situation précise: lorsque la zone de texte a le focus. Mais dans le cas contraire, la propriété plus appropriée est Value et non Text.
    Il faut aussi savoir que Text transforme les valeurs en type String. Si les valeurs doivent être comprises comme des nombres par exemple, il faut penser à les convertir... Par contre, en VB (je ne connais pas les versions au delà de VB6), le contenu d'une zone de texte est accessible par la propriété Text.
    Veuillez me corriger si je me trompe.

    En ce qui concerne nz, c'est une fonction qui renvoie une autre valeur lorsque la valeur d'un champ est nulle.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    nz(Me.Contrôle,0) 'renvoie 0 si Me.Contrôle est null
    Bon courage et @+
    La théorie, c'est quand on sait tout et que rien ne fonctionne. La pratique, c'est quand tout fonctionne et que personne ne sait pourquoi. Ici nous avons réuni théorie et pratique: Rien ne fonctionne ... et personne ne sait pourquoi!
    Albert Einstein

  15. #15
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    Je ne comprends pas pourquoi ca ne fonctionne pas, que ce soit avec ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    If Sous_Ensemble.Text <>"430-1" Then
       Me.Commentaire_Réf.Value = "0"
       Me.Descriptif_Réf.Value = "0"
    End If
    ou avec celui là
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    If Sous_Ensemble.Text <>"430-1" Then
       Me.Commentaire_Réf.Text = "0"
       Me.Descriptif_Réf.Text = "0"
    End If
    Il ne me trouve pas d'erreur et il n'effectue pas la tache que je lui demande.

    Cordialement,
    Bubut

  16. #16
    Membre expert
    Avatar de mout1234
    Profil pro
    Inscrit en
    Novembre 2006
    Messages
    2 210
    Détails du profil
    Informations personnelles :
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Novembre 2006
    Messages : 2 210
    Points : 3 228
    Points
    3 228
    Par défaut
    As-tu bien relu nos messages...

    Essaie
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Sous_Ensemble.Value ou Sous_Ensemble
    Dans tes deux exemples tu a laissé Sous_Ensemble.Text


    Essaie donc
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    If Me!Sous_Ensemble.Value<>"430-1" Then  
          Me!Commentaire_Réf.Value = "0"  
          Me!Descriptif_Réf.Value = "0" 
    End If
    PS: je reste un peu perplexe quant à la valeur du critère et aux valeurs affectées... mais bon ... c'est peut être logique ... je n'ai pas ton écran sous le nez
    ............................................................................................

    Dans l'intérêt de tous, ne posez pas de questions techniques par messages privés.

  17. #17
    Membre à l'essai
    Inscrit en
    Avril 2007
    Messages
    70
    Détails du profil
    Informations personnelles :
    Âge : 38

    Informations forums :
    Inscription : Avril 2007
    Messages : 70
    Points : 24
    Points
    24
    Par défaut
    En faite je laisse Text car j'utilise déja cette condition donc je sais qu'elle est bonne.

  18. #18
    Membre expérimenté
    Avatar de Mahefasoa
    Homme Profil pro
    Manager IT
    Inscrit en
    Octobre 2003
    Messages
    835
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Madagascar

    Informations professionnelles :
    Activité : Manager IT

    Informations forums :
    Inscription : Octobre 2003
    Messages : 835
    Points : 1 664
    Points
    1 664
    Par défaut
    Bonjour,
    Citation Envoyé par Bubut
    En faite je laisse Text car j'utilise déja cette condition donc je sais qu'elle est bonne.
    J'ai simulé ton code chez moi et il fonctionne. Bien entendu, il est clair que je n'ai pas tous les paramètres de ton environnement de travail et ceux de l'application.
    Mais écoutes, si ton problème se situe au niveau du fait que tu crains les valeurs nulles renvoyées par les contrôles, pourquoi ne pas utiliser la fonction nz comme on te l'a montré plus haut.
    Un tour à la ou une recherche sur ce forum te sera très utile.
    Bon dimanche et @lundi.
    La théorie, c'est quand on sait tout et que rien ne fonctionne. La pratique, c'est quand tout fonctionne et que personne ne sait pourquoi. Ici nous avons réuni théorie et pratique: Rien ne fonctionne ... et personne ne sait pourquoi!
    Albert Einstein

Discussions similaires

  1. Mettre du gras dans une zone de texte
    Par gontrand16 dans le forum IHM
    Réponses: 6
    Dernier message: 11/12/2012, 12h38
  2. Réponses: 14
    Dernier message: 22/11/2009, 05h48
  3. Mettre un lien cliquable dans une zone de texte
    Par mlny84 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 07/09/2009, 22h23
  4. Réponses: 2
    Dernier message: 09/01/2009, 11h51
  5. mettre en gras aligner un texte dans une zone de texte
    Par zaynabe dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 24/11/2007, 12h55

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