Exercice 17 : Création de la vue  » Pourcentages d’Evolutions  » de l’exercice 11 avec une boucle FOR.

Introduction

Il faut donc que l’utilisateur de l’exercice 11(Commandis) soit capable de visualiser les Pourcentages d’évolution du prix d’un objet quelconque en tapant sa référence. (Il est aidé pour cela par un JQUERY AUTOCOMPLETE, lorsqu’il tape dans le champs.). Il doit aussi visualiser la date de changement du pourcentage d’évolution du prix dans le graphe qui va se générer. Comme d’hab, il s’agit d’un pseudo MVC avec AJAX->VUE->GENEREJSON-GENEREGRAPHE

Ma méthode pour y arriver :

Tout d’abord, je lis le théorème des pourcentages d’évolution dans un livre de PREBABAC 1ère ES de Nathan Copyright 2008:

maths1

Ensuite, vu qu’il n’y a pas d’UML2.0, je pense les variables mathématiques dans le contexte de l’exercice 11, un peu à l' »arrache ». Comme d’hab, faut remplacer les var mathématiques par des vars « informatiques »… La difficulté ici, est que nous n’avons pas qu’un seul pourcentage d’évolution à calculer, mais un tableau …D’ou l’idée de la boucle For.

L' »ordonnancement » du traitement dans la vue sera donc celui-ci (J’ai choisi cela) :

1. Une Requête SQL en Lecture sous le critère référence de l’objet, qui va donc chercher tous les prix d’un objet puis les trie par date.

2. Création de 3 tableaux
-Les dates
-les Prix
-Et une copie du tableau prix.
Ceux ci sont en quelque sorte « synchronisés  » de par leur ids qui sont identiques, ce qui va permettre de réassembler le tableau des dates et celui des pourcentages $Pe qui aura été généré.

3. L’idée est d’avoir 2 tableaux des prix identiques afin de pouvoir traiter à l’aide d’une boucle for les variables PRIX  » de départ » et PRIX « d’arrivée ». Ensuite, je crée mon pourcentage et l’injecte dans un nouveau tableau de pourcentage $Pe dans la boucle for qui sera ensuite collé à mon tableau de date $tabDates. C’est la solution que j’ai trouvé. L’index du prix dans ma première boucle for sera $x, et je vais me servir de cet index de cette façon $x-1 ou $x+1 afin de me déplacer dans mon tableau pour faire les calculs conformément au théorème du livre prépabac puis les injecter dans $Pe.

4. Au final, le tableau $tabF qui comprends les dates et les pourcentages est converti au format JSON et nous obtenons une vue très importante suceptible d’être utilisée dans un Graphe !
En l’occurrence, c’est JQPLOT qui va devoir être également paramétré pour les dates et les pourcentages(C’est assez difficile).

Le code :

C’est une vue, il n’y a donc qu’un fichier:
afficherPourcentages.php

<?php
include('connexionSql.php');
indique que le type de la réponse renvoyée au client sera du Texte
header(&quot;Content-Type: text/plain&quot;);
//anti Cache pour HTTP/1.1
header(&quot;Cache-Control: no-cache , private&quot;);
//anti Cache pour HTTP/1.0
header(&quot;Pragma: no-cache&quot;);

// Transmission des var qui arrivent en mode get en variables classique PHP
$referenceP= $_GET['referenceP'];

connexionSql();
$lectureSql=&quot;Select date,prix from livraison where reference like ".$referenceP." order by livraison.date;&quot;;
$lecture = mysql_query($lectureSql) or die(mysql_error());

/* REQUETE SQL pour GRAPHE 1 */
/* POURCENTAGE DEVOLUTION DES PRIX PAR DATES*/
/* -----------------------------------------------------------------------------------------------------	 */	
while ($col=mysql_fetch_array($lecture)){
		$col[prix]=intval($col[prix]); 
		$tabPrix[] = $col[prix];
		$tabDates[] = $col['date'];
		$tabCopie[]=$col[prix];
}
/* -------------------------------------------------------------------------------------------------------- */

 // CALCUL ET POSITIONNEMENT DES POURCENTAGES D EVOLUTION des prix dans le tableau $Pe
for ($x=0;$x<sizeof($tabPrix);$x++){
	$Pe[$x]=$tabCopie[$x+1]-$tabPrix[$x];// IDEM LIVRE MATHSPREPABAC
	$Pe[$x]=$Pe[$x]/$tabPrix[$x]*100; // FORMULE DU LIVRE PREPABAC
	};

// ENLEVE LE DERNIER POURCENTAGE DU TABLEAU PE QUI EST forcement a zero et ne sert à rien
$size=sizeof($Pe)-1;
unset($Pe[$size]);

// INJECTION DES POURCENTAGES DEVOLUTION DANS LE TABLEAU DES DATES
for ($z=0;$z<sizeof($Pe);$z++){
	$tabF[]=array($tabDates[$z+1],$Pe[$z]);
	}

echo json_encode($tabF);

Voici les données JSON générées, Je n’ai pas encore arrondi les pourcentages à x.xx%, parce que certains moteurs de graphes le font par défaut. On voit donc que le 17 Septembre 2014, prix de notre article a bondi de 175.9 pour cent:

[["2014-09-17",175.86206896552],["2014-09-17",400],["2014-09-17",5.2],["2014-09-20",-87.690114068441],["2014-09-20",33.204633204633]]

Pour contrôle, on voit bien que ces pourcentages d’évolution correspondent bien aux données de PRIX de la requête SQL concernant l’article de référence gh2012 :

exercice17-1

Note : Ces données ne sont pas réalistes, car généralement, le prix d’un article ne peux bondir de 400 pour cent en une journée, ce qui nous donne des pourcentages d’évolution grotesques du style +400% ou -87.7% …

Note:
Jqplot a besoin de placer ces donnnées entre deux crochets additionels, ce qui donne (J’lai pas encore fait dans le code):

[[["2014-09-17",175.86206896552],["2014-09-17",400],["2014-09-17",5.2],["2014-09-20",-87.690114068441],["2014-09-20",33.204633204633]]]

Publicités