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

VB.NET Discussion :

imiter la fonction excel "PercentRank"


Sujet :

VB.NET

  1. #1
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    342
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 342
    Points : 107
    Points
    107
    Par défaut imiter la fonction excel "PercentRank"
    Salut,

    J'aurais besoin d'imiter la fonction excel "PercentRank". D'apres ce que j ai cru comprendre, elle n est pas directement implementée en .net.

    D apres ce que j ai compris de l'article wiki ou d'autres sites web, pour calculer le percentrank il faut :

    Si on cherche le Percentrank de X, il faut rechercher:
    - le nombre de valeurs inferieures a X dans le dataset (Cl dans l article wiki)
    - le nombre de fois que X est present dans le dataset (fi dans l article wiki)
    - le nombre total de valeurs dans le dataset (N dans l article wiki)

    Puis la formule serait donc (Cl + 0.5*fi)/N

    Mon probleme est qu avec mon code, si j'utilise cette simple formule, je ne retombe pas exactement sur les valeurs que me donne Excel. Si je considere par exemple la liste de valeurs suivantes:
    13,12,11,8,4,3,2,1,1,1

    Si je considere les valeurs X suivantes: 2,4,8 et 5, j'obtiens par excel / Par la formule les valeurs suivntes :

    2 ---> 0.333 pour Excel et 0.35 par la fromule
    4 ---> 0.555 pour Excel et 0.55 par la formule
    8 ---> 0.625 pour excel et 0.65 par la formule
    5 ---> 0.583 pour Excel et 0.6 par la formule

    Quelqu un saurait pourquoi ?

    Mon code :
    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
    Public Shared Function PercentRank(ByVal Pctl As Double, ByVal ValueList As List(Of Double)) As Double
     
            Dim SelectedFlows As New List(Of Double)((ValueList.GetRange(0, ValueList.Count)))
     
            SelectedFlows.Sort()
     
            Dim NumElems As Integer = SelectedFlows.Count
            Dim Cl As Integer = 0
            Dim fi As Integer = 0
     
            'search nbr of values below
            For i As Integer = 0 To NumElems - 1
                If SelectedFlows(i) < Pctl Then
                    Cl = i
                ElseIf SelectedFlows(i) = Pctl Then
                    fi = fi + 1
                Else
                    Exit For
                End If
            Next
     
            PercentRank = (Cl + 0.5 * fi) / NumElems
     
        End Function
    Merci

    Slumpy

  2. #2
    Membre chevronné
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2009
    Messages
    1 048
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : Suisse

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Avril 2009
    Messages : 1 048
    Points : 2 201
    Points
    2 201
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
            Dim Cl As Integer = 0
            Dim fi As Integer = 0
    A la vue des instructions, déclarer ces variable en tant que Integer au lieu de double, c'est jouer avec le feu !

  3. #3
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    et double plutot que decimal ca peut changer quelques chiffres aussi je crois ^^
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  4. #4
    Membre régulier
    Inscrit en
    Mars 2006
    Messages
    342
    Détails du profil
    Informations forums :
    Inscription : Mars 2006
    Messages : 342
    Points : 107
    Points
    107
    Par défaut
    Salut et merci d avoir pris 2 min pour lire mon message et y répondre.

    Pourquoi ne doivent ils pas être des entiers puisqu'il s agit d'un nombre d occurrence ? soit il y a 2 valeurs inférieures a X, soit 3, mais pas 2 et demi ou autre non entier ... Idem pour le nombre de fois ou X est present dns le dataset.

    A moins que je n ai pas compris un truc ?

    Slumpy

  5. #5
    Expert éminent sénior Avatar de Pol63
    Homme Profil pro
    .NET / SQL SERVER
    Inscrit en
    Avril 2007
    Messages
    14 154
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Puy de Dôme (Auvergne)

    Informations professionnelles :
    Activité : .NET / SQL SERVER

    Informations forums :
    Inscription : Avril 2007
    Messages : 14 154
    Points : 25 072
    Points
    25 072
    Par défaut
    moi je n'avais pas regardé le code je ne faisais que répondre à sinople
    mais en effet int suffit
    Cours complets, tutos et autres FAQ ici : C# - VB.NET

  6. #6
    Membre éprouvé
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    665
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 665
    Points : 1 161
    Points
    1 161
    Par défaut
    bonjour,
    en ouvrant le lien fourni et en suivant celui du chapitre "See also" : "Percentile", on tombe sur une méthode alternative employée par excel, que l'on peut adapter ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    PercentRankExcel = Cl / (NumElems - 1)
    C'est valable pour les valeurs présentes dans la liste.
    Pour celles entre deux, il faudra développer.
    Dans l'exemple fourni, pour 5 :
    0,583 = un quart entre le RANG.POURCENTAGE.INCLURE de 4 et le RANG.POURCENTAGE.INCLURE de 8)

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