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

Langage PHP Discussion :

Calcul pourcentage d'une variation entre deux valeurs


Sujet :

Langage PHP

  1. #1
    Membre régulier
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Mai 2008
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux

    Informations forums :
    Inscription : Mai 2008
    Messages : 231
    Points : 82
    Points
    82
    Par défaut Calcul pourcentage d'une variation entre deux valeurs
    Bonjour à tous, depuis plusieurs je me prends la tête pour monter une fonction simple et qui marche correctement.

    Le contexte : j'extrais depuis une base de données des chiffres de ventes (facturés et avoirs) réalisées sur une plage de date pour un groupe de produits que je compare pour en calculer le pourcentage de varration de chaque groupe.

    Exemple : J'ai 3 groupes de produits (A1, A2, A3), j'extrais pour chaque groupes, pour la plage de mois de janvier à mars 2018 et la même plage pour 2019, le chiffre de ventes.

    Résultat :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     ______|__2018 __|__2019__
    |  A1  | -198,20 |   0,00
    |  A2  |    0,00 |  40,29
    |  A3  | 1364,07 | 413,61
    J'obient :
    A1 = 100%
    A2 = 0%
    A3 = -69,68%

    Mon code php pour arriver à ce résultat

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    	public function getPercent($value1, $value2) {
    		if(($value1 == 0.00)) {
    			$percent = '0';
    		} elseif ($value1 < 0.00) {
    			$percent = (($value2/$value1)*100-100)*-1;
    		} else {
    			$percent = ($value2/$value1)*100-100;
    		}
     
    		return $percent;
    	}
    Sauf que c'est pas vraiment juste, enfin mathématiquement si, mais commercialement non.

    Pour A1 j'ai en 2018 un chiffre négatif ce qui veut dire que le client a fait 0€ et qu'il a eu un avoir de 198,20€ donc -198,20€ et en 2019 il a encore fait 0€ de vente. Ma fonction me sort 100% de variation sauf que réellement il a fait 0% (l'avoir peut être un reste de l'année précédente).

    Pour A2, en 2018 il a fait 0€ de vente et en 2019 il a fait 40,29€. Ma fonction sort 0% alors que là c'est 100% de variation.

    Pour A3... En fait c'est le seul cas où le résultat me parait être le bon.

    Donc je vois deux cas possibles :
    • Je m'y prends vraiment comme un pied;
    • Vous avez une fonction qui va bien dans vos besaces pour me sortir de ce piège.



    Des idées ?

    Merci d'avance.

  2. #2
    Modérateur

    Avatar de MaitrePylos
    Homme Profil pro
    DBA
    Inscrit en
    Juin 2005
    Messages
    5 496
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : Belgique

    Informations professionnelles :
    Activité : DBA
    Secteur : Service public

    Informations forums :
    Inscription : Juin 2005
    Messages : 5 496
    Points : 12 596
    Points
    12 596
    Par défaut
    Bonjour,
    De ce que je comprend, vous ne prenez en compte que la value1, du coup cela ne peux marcher.
    Vous devez emmètre tout les cas et faire votre discrimination en fonction de.

Discussions similaires

  1. Réponses: 4
    Dernier message: 08/01/2014, 13h50
  2. [XPATH] Rechercher une valeur entre deux valeurs min et max
    Par icicmoi dans le forum XSL/XSLT/XPATH
    Réponses: 1
    Dernier message: 27/10/2008, 12h12
  3. calcul d'une somme entre deux années
    Par alex77140 dans le forum IHM
    Réponses: 5
    Dernier message: 08/07/2008, 08h00
  4. [Time] comment calculer une différence entre deux Time?
    Par adil_vpb dans le forum API standards et tierces
    Réponses: 12
    Dernier message: 13/03/2007, 17h02
  5. [Dates] Calcul d'une différence entre deux heures
    Par loreleï85 dans le forum Langage
    Réponses: 12
    Dernier message: 28/06/2006, 11h43

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