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 :

fonctions pour mettre en classe


Sujet :

Macros et VBA Excel

  1. #1
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Août 2007
    Messages
    184
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2007
    Messages : 184
    Par défaut fonctions pour mettre en classe
    Bonjour à tous,
    Novice du forum Excel

    a) Je souhaiterais savoir s'il existe des fonctions Excel équivalentes aux fonctions Partition ou Switch d'Access, pour mettre en classe une variable.

    Pour l'instant, sous Excel, je fais des mises en classes avec des fonctions SI imbriqués

    b) J'ai ce code VBA sous Access..

    Comment le mettre en oeuvre sous Excel ? (je redis novice sous VBA Excel )
    que faut il ouvrir ?

    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
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
     
    Public Function MiseEnClasse(Valeur As Variant, Pas As Variant)
    ' attention :
    ' pas de 1 : maximum 51
    ' pas de 10 : maximum : 210
    ' pas de 0.5 : maximum : 15.5
    ' pas de 50 : maximum : 500
      Dim BorneInf, BorneSup As Variant
      Dim I As Integer
      If VarType(Valeur) = vbNull Then
        MiseEnClasse = "[0]"
        Exit Function
      End If
      ' gestion de la valeur 0
      If Valeur = 0 Or Valeur < 0 Then
        MiseEnClasse = "[0]"
        Exit Function
      End If
      If Pas = 1000 Then
        BorneInf = Array(-1, 0, 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000, 9000, 10000, 11000, 12000, 13000, 14000, 15000)
        BorneSup = Array(0, 1000, 2000, 3000, 4000, 5000, 6000, 7000, 8000, 9000, 10000, 11000, 12000, 13000, 14000, 15000, 16000)
      End If
      If Pas = 50 Then
        BorneInf = Array(-1, 0, 50, 100, 150, 200, 250, 300, 350, 400, 450, 500)
        BorneSup = Array(0, 50, 100, 150, 200, 250, 300, 350, 400, 450, 500)
      End If
      If Pas = 10 Then
        BorneInf = Array(-1, 0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140, 150, 160, 170, 180, 190, 200)
        BorneSup = Array(0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 140, 150, 160, 170, 180, 190, 200, 210)
      End If
      If Pas = 5 Then
        BorneInf = Array(-1, 0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100)
        BorneSup = Array(0, 5, 10, 15, 20, 25, 30, 35, 40, 45, 50, 55, 60, 65, 70, 75, 80, 85, 90, 95, 100, 200)
      End If
       If Pas = 1 Then
        BorneInf = Array(-1, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50)
        BorneSup = Array(0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51)
      End If
      If Pas = 0.5 Then
        BorneInf = Array(-1, 0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 8.5, 9, 9.5, 10, 10.5, 11, 11.5, 12, 12.5, 13, 13.5, 14, 14.5, 15)
        BorneSup = Array(0, 0.5, 1, 1.5, 2, 2.5, 3, 3.5, 4, 4.5, 5, 5.5, 6, 6.5, 7, 7.5, 8, 8.5, 9, 9.5, 10, 10.5, 11, 11.5, 12, 12.5, 13, 13.5, 14, 14.5, 15, 15.5)
      End If
       If Pas = 0.1 Then '10/01/2006
        BorneInf = Array(-0.1, 0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1#, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2#, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6, 2.7, 2.8, 2.9, 3)
        BorneSup = Array(0, 0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1#, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7, 1.8, 1.9, 2#, 2.1, 2.2, 2.3, 2.4, 2.5, 2.6, 2.7, 2.8, 2.9, 3, 3.5)
      End If
     
     
      I = 1
      Do Until Valeur >= BorneInf(I) And Valeur < BorneSup(I)
         I = I + 1
         If Pas = 1 And I = 51 Then GoTo sort
         If Pas = 10 And I = 21 Then GoTo sort
         If Pas = 5 And I = 21 Then GoTo sort
         If Pas = 0.5 And I = 21 Then GoTo sort
         If Pas = 0.1 And I = 21 Then GoTo sort
      Loop
    sort:
         If Pas = 10 And I = 12 Then BorneSup(12) = 100
      If Pas = 10 And I = 12 Then
        MiseEnClasse = "[" & str(BorneInf(I)) & "]"
        Exit Function
      End If
      MiseEnClasse = "[" & str(BorneInf(I)) & ";" & str(BorneSup(I)) & "["
    End Function

    Grand merci pour vos pistes

    fevec

  2. #2
    Membre éprouvé
    Inscrit en
    Mai 2008
    Messages
    104
    Détails du profil
    Informations forums :
    Inscription : Mai 2008
    Messages : 104
    Par défaut
    Bonjour,
    Pour la première question, je ne crois pas mais ce n'est pas une preuve,
    Pour la deuxième :
    Alt F11
    Insertion, Module
    Colle ton code dedans,
    C'est tout !

    Testé : =MiseEnClasse(1002;10) renvoie [ 200; 210[

  3. #3
    Membre éprouvé Avatar de Commodore
    Homme Profil pro
    Business manager
    Inscrit en
    Février 2004
    Messages
    599
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Business manager

    Informations forums :
    Inscription : Février 2004
    Messages : 599

  4. #4
    Membre confirmé
    Homme Profil pro
    Inscrit en
    Août 2007
    Messages
    184
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2007
    Messages : 184
    Par défaut
    Merci

    1°) entre temps, j'avais trouvé via les menus.
    mais merci pour le Alt F11 qui va bien !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    ' attention :
    ' pas de 1 : maximum 51
    ' pas de 10 : maximum : 210
    ' pas de 0.5 : maximum : 15.5
    ' pas de 50 : maximum : 500
    le test est "faux " car la fonction est limitée sur la place de valeur
    (par pas de 10; on s'arrête à 210)


    2°)
    Oui, oui, je sais c'est du vba de "bucheron"...
    à revoir avec du select case

    L'idéal serait de générer les Array par code en fonction de la valeur.
    mais ça je ne sais pas (encore) faire

    Une petite suggestion ?

    merci en tout cas !

    fevec

Discussions similaires

  1. [AC-2010] fonction pour mettre à jour un champ en majuscule
    Par bremmo76 dans le forum Access
    Réponses: 6
    Dernier message: 23/09/2010, 22h53
  2. Fonction pour mettre en gras du texte
    Par lemathurin dans le forum Macros et VBA Excel
    Réponses: 7
    Dernier message: 24/08/2010, 15h38
  3. appeler fonction d'une autre classe pour faire une opération
    Par AzraHell dans le forum Débuter avec Java
    Réponses: 13
    Dernier message: 31/03/2009, 20h32
  4. Réponses: 3
    Dernier message: 26/09/2006, 11h17
  5. Réponses: 12
    Dernier message: 22/02/2005, 17h45

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