Le contexte : Un script php parse ligne par ligne un fichier texte et effectue une additionn des valeurs ensemble( TVA+HT==TTC) et fait une comparaison à l'aide de == , hors dans certains cas l'opération est mathématiquement juste, mais PHP me sort un resultat bizarre.Les lignes sont en italiques dans le dernier extrait d'affichage. Merci d'avance pour toute aide ou piste ;-)
$array_fichierE=file($name_file_export); // on ouvre le fichier précédement de sortie en entrée
foreach($array_fichierE as $ligne) // on parse le fichier ligne par ligne
{
$champ=explode(",",$ligne); // on éclate les lignes
$ht=$champ[6]+$champ[8]+$champ[10]+$champ[12]; // on additionne les valeurs toute les deux colonne à partir de la 6ième jusqu'a la fin
if ($ht == $champ[4]){ // ht doit être egal à ttc
echo "<font color=green>N°: ".$champ[1]." TVA+HT: ".$ht." EST EGAL AU TTC:".$champ[4]."</font><br>";} // un affichage juste pour verif
else {
echo "<font color=red>N°: ".$champ[1]." TVA+HT: ".$ht." N'EST PAS EGAL AU TTC:".$champ[4]."</font><br>";}
}
un affichage de verif après traitement du texte:
N°: TA550 TVA+HT: 454.48 EST EGAL AU TTC: 454.48
N°: TA551 TVA+HT: 5502.37 N'EST PAS EGAL AU TTC: 5502.37
N°: TA552 TVA+HT: 5262.4 EST EGAL AU TTC: 5262.40
N°: TA553 TVA+HT: 3961.8 EST EGAL AU TTC: 3961.80
N°: TA554 TVA+HT: 454.48 EST EGAL AU TTC: 454.48
N°: TA555 TVA+HT: 15 EST EGAL AU TTC: 15.00
N°: TA556 TVA+HT: 7893.6 EST EGAL AU TTC: 7893.60
N°: TA557 TVA+HT: 227.24 EST EGAL AU TTC: 227.24
N°: TA558 TVA+HT: 227.24 EST EGAL AU TTC: 227.24
N°: TA559 TVA+HT: 15 EST EGAL AU TTC: 15.00
N°: TA560 TVA+HT: 10524.8 EST EGAL AU TTC: 10524.80
N°: TA561 TVA+HT: 2631.2 EST EGAL AU TTC: 2631.20
N°: TA562 TVA+HT: 2751.18 N'EST PAS EGAL AU TTC: 2751.18
N°: TA563 TVA+HT: 5277.4 EST EGAL AU TTC: 5277.40
N°: TA564 TVA+HT: 2631.2 EST EGAL AU TTC: 2631.20
N°: TA565 TVA+HT: 2631.2 EST EGAL AU TTC: 2631.20
N°: TA566 TVA+HT: 2631.2 EST EGAL AU TTC: 2631.20
N°: TA567 TVA+HT: 1315.6 EST EGAL AU TTC: 1315.60
N°: TA568 TVA+HT: 227.24 EST EGAL AU TTC: 227.24
N°: TA571 TVA+HT: 11079.72 EST EGAL AU TTC: 11079.72
N°: TA572 TVA+HT: 2706.19 N'EST PAS EGAL AU TTC: 2706.19
N°: TA569 TVA+HT: 227.24 EST EGAL AU TTC: 227.24
N°: TA570 TVA+HT: 227.24 EST EGAL AU TTC: 227.24
N°: TA573 TVA+HT: 2751.18 N'EST PAS EGAL AU TTC: 2751.18
N°: TA574 TVA+HT: 2631.2 EST EGAL AU TTC: 2631.20
Je me demande s'il faudrait pas que j'ajoute un test de valeur ( !=0 et != "") sur les $champ[6]+$champ[8]+$champ[10]+$champ[12].Pourtant on vois bien sur d'autre ligne que meme si une des valeurs vaut 0 ou " " ça n'a pas l'air de gener PHP, mais bon comme je vois rien d'autre pour l'instant..
Pour une raison que j'ignore, dans 2 cas $ht est plus grand de 0,000000000000454747350886 et dans un cas $ht est plus petit de 0,000000000000454747350886 et dans le premier cas $ht est plus grand de 0,000000000000909494701773.
(à 1 virgule près).
$ht=$champ[6]+$champ[8]+$champ[10]+$champ[12]; // on additionne les valeurs toute les deux colonne à partir de la 6ième jusqu'a la fin
dans plusieurs de tes lignes, tu n'as pas autant de champs (12) ?
C'est curieux que Php ne te sorte pas une erreur (index inexistant dans l'array ??)
tu devrais peut être faire une boucle:
$champ=explode(",",$ligne);
$ht=0;// va créer une variable de type numérique
foreach($champ as $cle=>$value){
if($cle==6 OR $cle==8 OR $cle == 10 OR $cle==12){
$ht+=$value;
}
}
j'ai fait pleins d'essais, les deux valeurs comparées sont bien numériques et php a un comportement bizarre.
Alors je les force à variable chaine avant comparaison et la ça marche:(les puristes vont bondir !)
$array_fichierE=file('fich_texte.txt'); // on ouvre le fichier précédement de sortie en entrée
foreach($array_fichierE as $ligne) // on parse le fichier ligne par ligne
{
$champ=explode(",",$ligne);
$ht=0;// va créer une variable de type numérique
foreach($champ as $cle=>$value){
if($cle==6 OR $cle==8 OR $cle == 10 OR $cle==12){
$ht+=trim($value);
}
}
settype($champ[4],'string');// on force le type de variable en chaine
settype($ht,'string');
if ($ht == trim($champ[4])){ // ht doit être egal à ttc
echo "<font color='green'>N°: ".$champ[1]." TVA+HT: ".$ht." EST EGAL AU TTC:".$champ[4]."</font><br>";} // un affichage juste pour verif
else {
echo "<font color='red'>N°: ".$champ[1]." TVA+HT: ".$ht." N'EST PAS EGAL AU TTC:".$champ[4]."</font><br>";}
}
Je n'aurais pas trouvé comme ça.J'ai testé ça marche ainsi et je peux tout à fait faire évoluer si les lignes changent!
Apparemment dans un tableau (verifié avec intval) si la ou on pointe c'est vide numériquement, c'est pas tout à fait vide quand même puisque intval me retourne 1 dans ces fameuse lignes.Alors que pour moi c'est nul evidemment. Après si la variable est utilisé avec un opérateur comme j'ai fait, sans passer par Mr propre, je ne sais pas ce qui se passe.Php n'aime pas le vide, je dirais ;-)