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 :
J'obient :
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
A1 = 100%
A2 = 0%
A3 = -69,68%
Mon code php pour arriver à ce résultat
Sauf que c'est pas vraiment juste, enfin mathématiquement si, mais commercialement non.
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; }
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.
Partager