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 :

Affectation à une constante non autorisée [XL-2013]


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Homme Profil pro
    Etudiant
    Inscrit en
    Juin 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 21
    Par défaut Affectation à une constante non autorisée
    Bonjour,

    J'ai des références dans une feuille excel dans la colonne A. J'aimerais que mon programme compte le nombre de référence ayant la même ref que dans une ComboBox (ChoixFRAISE) et que le résultat soit afficher dans une TextBox (TextBox10).

    Ma ligne de code qui bug est :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    y = Me.ChoixFRAISE.Value
    Application.WorksheetFunction.CountIf(Range("A2:A65000"), y) = Me.TextBox10.Value
    Quand je lance mon programme, un message d'erreur apparait avec marqué : "Affectation à une constante non autorisée" (le programme est lancé à partir d'un bouton).

    J'ai essayé en affectant une variable y pour la valeur qui sera sélectionnée dans la combobox mais je sais pas si c'est la bonne solution... De plus, j'ai aussi essayé avec Range(A2,A65000), ça ne marche pas non plus.

    Merci d'avance pour votre aide !

  2. #2
    Membre Expert
    Femme Profil pro
    Ingénieur
    Inscrit en
    Octobre 2016
    Messages
    1 706
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 30
    Localisation : France, Indre et Loire (Centre)

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2016
    Messages : 1 706
    Par défaut
    Bonjour,
    Attention :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Range("A1").Value = "toto"            'j'affecte la valeur "toto" à la cellule A1
    Range("A1").Value = Range("A2").Value    'j'affecte la valeur de la cellule A2 à la cellule A1
    Range("A2").Value = Range("A1").Value    'j'affecte la valeur de la cellule A1 à la cellule A2
    Regarde bien ton égalité.

  3. #3
    Membre Expert Avatar de antonysansh
    Homme Profil pro
    Chargé d'études RH
    Inscrit en
    Mai 2014
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 34
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Chargé d'études RH
    Secteur : Finance

    Informations forums :
    Inscription : Mai 2014
    Messages : 1 115
    Par défaut
    Bonjour,

    Cette ligne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.WorksheetFunction.CountIf(Range("A2:A65000"), y) = Me.TextBox10.Value
    n'a pas de sens.

    Tu es en train de dire que le résultat de la formule doit être la valeur de la TextBox10. Donc impossible.

    Tu dois donc écrire l'inverse :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.TextBox10.Value = Application.WorksheetFunction.CountIf(Range("A2:A65000"), y)

  4. #4
    Membre averti
    Homme Profil pro
    Etudiant
    Inscrit en
    Juin 2015
    Messages
    21
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Loire (Rhône Alpes)

    Informations professionnelles :
    Activité : Etudiant

    Informations forums :
    Inscription : Juin 2015
    Messages : 21
    Par défaut
    Merci à tous pour vos réponses, ca marche parfaitement ! Désolé pour la question bete mais je débute en VBA et j'apprends tout seul ^^

    Merci !

  5. #5
    Expert éminent
    Avatar de Marc-L
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2013
    Messages
    9 468
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2013
    Messages : 9 468
    Par défaut
    Bonjour,

    la ligne n°2 telle quelle n'a aucun sens !   La destination du résultat devant être à gauche du signe égal …

    Et .WorksheetFunction est inutile, Application suffisant largement …

    ___________________________________________________________________________________________________________
    Je suis Paris, Egypte, Stockholm, London, Istanbul, Berlin, Nice, Bruxelles, Charlie, …


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

Discussions similaires

  1. Réponses: 0
    Dernier message: 02/08/2010, 15h50
  2. Réponses: 3
    Dernier message: 08/04/2009, 12h53
  3. Réponses: 3
    Dernier message: 22/02/2009, 22h27
  4. [Affectation] Méthode des Hongrois avec une matrice non carrée
    Par bmw13fr dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 12/09/2007, 15h38
  5. Affecter une requete (non en sql) a la fonction recordsource
    Par Titeuf59 dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 11/04/2007, 00h32

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