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 :

petit problème de variable


Sujet :

Macros et VBA Excel

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    203
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 203
    Par défaut petit problème de variable
    Bonjour , il est très simple d'écrire une fonction qui tire un nombre aléatoire entre 0 et un nombre X .
    Moi je souhaiterais savoir tirer un nombre aléatoire entre 0 et un nombre X , mais sachant que le nombre X correspond à la valeur qu'il y a dans la cellule ligne 8 colonne courante , colonne ù on se trouve quoi .

    Donc voici une idée de code que l'on doit modifier un peu :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    function aleaNombre()
    aleaNombre = Int(Rnd * X + 1)
    End Function
    Je dois donc donner comme valeur à X , la valeur qu'il y a dans la cellule ligne 10 et la colonne courante , quelqu'un voit comment faire ?
    J'ai essayé avec désignation de plage...mais rien n'y fait .

    merci

  2. #2
    Membre Expert Avatar de laetitia
    Profil pro
    Inscrit en
    Décembre 2002
    Messages
    1 281
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France

    Informations forums :
    Inscription : Décembre 2002
    Messages : 1 281
    Par défaut
    bonjour shaku le forum brute comme cela sans plus de precisions !!!

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function aleaNombre()
    aleaNombre = Int(Rnd * ActiveCell.Value + 1)
    End Function

  3. #3
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    203
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 203
    Par défaut
    euh non tu n'as pas compris ton code ne répond absolument pas à ce que je veux , relis bien lol

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

    Informations forums :
    Inscription : Février 2007
    Messages : 491
    Par défaut
    bonjour,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    function aleaNombre()
    aleaNombre = Int(Rnd * cells(10,ActiveCell.column) + 1)
    End Function

  5. #5
    Membre confirmé
    Inscrit en
    Octobre 2008
    Messages
    203
    Détails du profil
    Informations forums :
    Inscription : Octobre 2008
    Messages : 203
    Par défaut
    non ça ne va pas donc je vais bien préciser ce que je veux :

    Imaginez un tableau avec sur la 1ère ligne , dans chaque case des nombres différents . Dans chaque colonne du tableau je dois renvoyer un nombre aléatoire entre 0 et le nombre de la 1ère ligne .

    La macro qui réalise ceci je sais l'écrire , je dois juste écrire la fonction qui renvoie un entier compris entre 0 et le nombre de la 1ère ligne . Voici un exemple de tableau :

    20 50 30 ' 1ere ligne
    18 22 13 ' 2eme ligne
    15 50 12 '3eme ligne

    etc etc... Donc il me faut une fonction qui génére des nombres dans la 1ere colonne compris entre 0 et 20 , dans la seconde compris entre 0 et 50...

    J'espère que je m'explique assez précisément...

  6. #6
    Inactif  

    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    4 555
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 4 555
    Par défaut
    Bonsoir, Shaku,

    ta question est-elle finalement et simplement :
    Comment lire en boucle le contenu de cellules (pour en faire ensuite ce que tu veux,... tirer un nombre aléatoire ou pas, enfiler des chaussettes ou un pull-over ou pas) ?
    et écrire ce que tu veux (voir liste plus haut) où tu as décidé en fonction de l'endroit de ta lecture ?

  7. #7
    Membre émérite
    Avatar de ouisansdoute
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    931
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2007
    Messages : 931
    Par défaut
    Bonsoir,

    De ce que j'ai compris, sans passer par du code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    =ENT(ALEA()*$A$1+1) ' pour la colonne A
    en passant par du code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Int(Rnd * cells(1,ActiveCell.column) + 1)
    Mais c'est tellement proche de ce qui t'a été proposé que je ne suis pas sûre que ce soit la bonne réponse...

  8. #8
    Expert confirmé
    Avatar de Qwazerty
    Homme Profil pro
    La très haute tension :D
    Inscrit en
    Avril 2002
    Messages
    4 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : France

    Informations professionnelles :
    Activité : La très haute tension :D
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 121
    Par défaut
    Salut
    Pourquoi du vba ? les formules ne te conviennent elles pas? Je pense qu'il serait possible de réaliser cela.

    Pour trouver ce que tu cherches je te conseil de t'intéresser au fonction d'excel
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Application.WorksheetFunction....
    Notamment a Max, qui te permettra de trouver la valeur la plus haute de la plage (ta colonne courante)
    et Match qui te permettra de trouver la ligne qui contient la valeur que tu cherche.

    Si tu veux des infos détaillées sur ces fonctions, va dans excel et dans les fonction cherche Max (pour max la ca va) et Equiv 'pour match) comme ça tu sauras quoi mettre en paramètre.

    A++
    Qwaz

    MagicQwaz := Harry Potter la baguette en moins
    Le monde dans lequel on vit
    Ma page perso DVP
    Dernier et Seul Tutoriel : VBA & Internet Explorer
    Dernière contribution : Lien Tableau Structuré et UserForm
    L'utilisation de l’éditeur de message

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

Discussions similaires

  1. Morpion, petit problème de variables
    Par talapoga dans le forum Débuter
    Réponses: 5
    Dernier message: 29/04/2015, 09h01
  2. Petit problème de variable
    Par Askental dans le forum ActionScript 3
    Réponses: 0
    Dernier message: 18/08/2009, 17h39
  3. [AJAX] Déclaration de variable
    Par Halaster dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 06/03/2008, 16h53
  4. Réponses: 3
    Dernier message: 19/09/2006, 20h12
  5. petit problème variable perl bizzare
    Par Invité dans le forum Langage
    Réponses: 6
    Dernier message: 08/04/2006, 01h01

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