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 :

Champ dans un formulaire avec . ou ,


Sujet :

Macros et VBA Excel

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 491
    Points : 155
    Points
    155
    Par défaut Champ dans un formulaire avec . ou ,
    Bonsoir,

    J'ai créé un formulaire et parmis les champs, j'ai un champ "Cout_kgBox" dans lequel je met un prix. J'ai malheureuesment un message d'erreur lorsque je mets un . ou une virgule.
    voici le code d'erreur :
    Erreur d'exécution '13'
    Inompatibilité de type
    est ce que quelqu'un peut m'aider ?

    Merci

    Nini

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour

    Comment gères-tu cette information par la suite ?

    Est-ce que tu mets celle-ci dans une variable ? Si oui, il se peut qu'elle soit mal typé, par exemple avec un type Long ou Integer tu auras ce type d'erreur, si c'est le cas il faut typer en Double ou Single.

    Philippe

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    491
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 491
    Points : 155
    Points
    155
    Par défaut
    Bonjour,

    J'ai essayé ce que tu m'a dit mais cela ne change rien.

    Voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Cout_kgBox_Change()
    Dim PRBox As Single
    Dim Cout_kgBox As Single
     
    UserForm1.PRBox.Value = (UserForm1.PrixPlanteBox.Value * 1) + (UserForm1.Cout_kgBox.Value * 1)
    End Sub
    En espérant que cela puisse mieux vous orienter

    Nini

  4. #4
    Membre chevronné Avatar de rvtoulon
    Homme Profil pro
    Agent Technique
    Inscrit en
    Mars 2009
    Messages
    1 042
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Agent Technique
    Secteur : Santé

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 042
    Points : 2 003
    Points
    2 003
    Par défaut
    Tu déclare des variables, il faut t'en servir.
    tu peux essayer :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Private Sub Cout_kgBox_Change()
    Dim Cout_kgBox As Single, PrixPlanteBox As Single
     
    PrixPlanteBox = UserForm1.PrixPlanteBox.Value * 1
    Cout_kgBox = UserForm1.Cout_kgBox.Value * 1
     
    UserForm1.PRBox.Value = PrixPlanteBox + Cout_kgBox
     
    End Sub
    A quoi sert le "*1"?

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

    Informations professionnelles :
    Activité : solution provider

    Informations forums :
    Inscription : Mars 2006
    Messages : 4 087
    Points : 7 168
    Points
    7 168
    Billets dans le blog
    20
    Par défaut
    Salut,
    c'est un pb de champ vide je pense

    je l'ai mis dans un événement Afterupdate qui est peut être plus adapté (ne se déclenche que quand on change de zone

    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 Cout_kgBox_AfterUpdate()
        Dim Cout_kgBox As Single
        Dim PrixPlanteBox As Variant
     
        If IsNumeric(UserForm1.PRBox.Value) Then
            PrixPlanteBox = UserForm1.PRBox.Value * 1
        Else
            PrixPlanteBox = 0
        End If
        If IsNumeric(UserForm1.Cout_kgBox.Value) Then
        Cout_kgBox = UserForm1.Cout_kgBox.Value * 1
        End If
        UserForm1.PRBox.Value = PrixPlanteBox + Cout_kgBox
     
     
    End Sub

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

    Informations professionnelles :
    Activité : solution provider

    Informations forums :
    Inscription : Mars 2006
    Messages : 4 087
    Points : 7 168
    Points
    7 168
    Billets dans le blog
    20
    Par défaut
    ou comme cela c'est plus condensé
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    Private Sub Cout_kgBox_AfterUpdate()
        Dim Cout_kgBox As Single
        Dim PrixPlanteBox As Variant
     
        PrixPlanteBox = IIf(IsNumeric(UserForm1.PRBox.Value), UserForm1.PRBox.Value, 0) * 1
        Cout_kgBox = IIf(IsNumeric(UserForm1.Cout_kgBox.Value), UserForm1.Cout_kgBox.Value, 0) * 1
        UserForm1.PRBox.Value = PrixPlanteBox + Cout_kgBox
    End Sub

Discussions similaires

  1. Réponses: 2
    Dernier message: 18/06/2015, 16h53
  2. [AC-2003] Atteindre un champ dans un formulaire avec un raccourci clavier
    Par mouhamadrouabha dans le forum IHM
    Réponses: 7
    Dernier message: 17/03/2012, 15h44
  3. Réponses: 1
    Dernier message: 13/04/2011, 09h44
  4. Réponses: 13
    Dernier message: 22/10/2008, 09h19
  5. Réponses: 10
    Dernier message: 03/10/2006, 15h32

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