Section courante

A propos

Section administrative du site

Selon le professeur du département d'informatique du Cégep de Momo, François Leroux, un des algorithmes de base permettant une compréhension universel de la programmation pour un débutant, peu importe son origine, sa classe social ou sa culture, est sans nulle doute les taxes !

De plus, le Canada est sans doute l'un des pays ou les taxes de vente sur les produits et services sont les plus compliqués à appliquer. Et pour cause : Elle varie d'une province ou territoire à l'autre, elle est parfois composé ou séparé. Voici leur représentation en date du mois de septembre de l'année 2006 :

Province/Territoire Taxe 1 Taxe 2 Taux
Alberta TVH: 6% Aucune 6%
Colombie-Britannique TVH: 6% TVP: 7% 13%
Ile-du-Prince-Édouard TPS: 6% TVP: 10% 16.6%
Manitoba TPS: 6% TVP: 7% 13%
Nouveau-Brunswick TVH: 14% Aucune 14%
Nouvelle-Écosse TVH: 14% Aucune 14%
Nunavut TVH: 6% Aucune 6%
Ontario TPS: 6% TVP: 8% 14%
Québec TPS: 6% TVQ: 7.5% 13.95%
Saskatchewan TPS: 6% TVP: 7% 13%
Terre-Neuve/Labrador TVH: 14% Aucune 14%
Territoire du Nord Ouest TVH: 6% Aucune 6%
Territoire du Yukon TVH: 6% Aucune 6%

Tout d'abord, voici un premier exemple permet d'afficher des données complètes sur les taxes en PHP :

  1. <?php
  2. $Compute=array("C","C","C","C","S","C","S","S","S","S","C","S","S");
  3. $TaxName1=array("TPS","TVH","TVH","TVH","TPS","TVH","TPS","TVH","TVH","TPS","TPS","TPS","TVH");
  4. $TaxRate1=array(6.0000,14.0000,14.0000,14.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000);
  5. $TaxName2=array("TVQ","","","","TVP","","TVP","","","TVP","TVP","TVP","");
  6. $TaxRate2=array(7.5000,0.0000,0.0000,0.0000,7.0000,0.0000,7.0000,0.0000,0.0000,8.0000,10.0000,7.0000,0.0000);
  7. $RegionMID=array("QC","NS","NB","NF","BC","AB","MB","NT","NU","ON","PE","SK","YT");
  8. $RegionName_EN=array("Quebec","Nova Scotia","New Brunswick","Newfoundland","British Columbia","Alberta","Manitoba","Northwest Territories","Nunavut","Ontario","Prince Edward Island","Saskatchewan","Yukon Territory");
  9. $RegionName_FR=array("Québec","Nouvelle-Écosse","Nouveau-Brunswick","Terre-Neuve/Labrador","Colombie-Britanique","Alberta","Manitoba","Territoire du Nord Ouest","Nunavut","Ontario","Ile-du-Prince-Édouard","Saskatchewan","Territoire du Yukon");
  10.  
  11. echo "<TABLE>";
  12. echo "<TR>";
  13. echo "<TD><B>Nom de la province/territoire</B></TD>";
  14. echo "<TD><B>MID</B></TD>";
  15. echo "<TD><B>Taxe 1</B></TD>";
  16. echo "<TD><B>Taxe 2</B></TD>";
  17. echo "<TD><B>Taux</B></TD>";
  18. echo "</TR>";
  19. for($I=0;$I<count($RegionName_FR);$I++) {
  20.     echo "<TR>";
  21.     echo "<TD>" . $RegionName_FR[$I] . "</TD>";
  22.     echo "<TD>" . $RegionMID[$I] . "</TD>";
  23.     echo "<TD>" . $TaxName1[$I] . ":" . $TaxRate1[$I] . "%</TD>";
  24.     if($TaxName2[$I]=="") {
  25.         echo "<TD> </TD>";
  26.     } else {
  27.         echo "<TD>" . $TaxName2[$I] . ":" . $TaxRate2[$I] . "%</TD>";
  28.     }
  29.     echo "<TD>";
  30.     switch($Compute[$I]) {
  31.         case "S": //Séparé
  32.             echo strval($TaxRate1[$I]+$TaxRate2[$I]) . "%";
  33.             break;
  34.         case "C": //Composé
  35.             echo strval($TaxRate1[$I]+(($TaxRate2[$I]*(100+$TaxRate1[$I]))/100)) . "%";
  36.             break;
  37.     }
  38.     echo "</TD></TR>";
  39. }
  40. echo "</TABLE>"
  41. ?>

on obtiendra le résultat suivant :

Nom de la province/territoireMIDTaxe 1Taxe 2Taux
QuébecQCTPS:6%TVQ:7.5%13.95%
Nouvelle-ÉcosseNSTVH:14% 14%
Nouveau-BrunswickNBTVH:14% 14%
Terre-Neuve/LabradorNFTVH:14% 14%
Colombie-BritaniqueBCTPS:6%TVP:7%13%
AlbertaABTVH:6% 6%
ManitobaMBTPS:6%TVP:7%13%
Territoire du Nord OuestNTTVH:6% 6%
NunavutNUTVH:6% 6%
OntarioONTPS:6%TVP:8%14%
Ile-du-Prince-ÉdouardPETPS:6%TVP:10%16.6%
SaskatchewanSKTPS:6%TVP:7%13%
Territoire du YukonYTTVH:6% 6%

Ensuite, voici un deuxième exemple permet de calculer la taxe de vente d'un produit ou service en fonction des provinces ou territoires en PHP :

  1. <?php
  2. $Compute=array("C","C","C","C","S","C","S","S","S","S","C","S","S");
  3. $TaxName1=array("TPS","TVH","TVH","TVH","TPS","TVH","TPS","TVH","TVH","TPS","TPS","TPS","TVH");
  4. $TaxRate1=array(6.0000,14.0000,14.0000,14.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000,6.0000);
  5. $TaxName2=array("TVQ","","","","TVP","","TVP","","","TVP","TVP","TVP","");
  6. $TaxRate2=array(7.5000,0.0000,0.0000,0.0000,7.0000,0.0000,7.0000,0.0000,0.0000,8.0000,10.0000,7.0000,0.0000);
  7. $RegionMID=array("QC","NS","NB","NF","BC","AB","MB","NT","NU","ON","PE","SK","YT");
  8. $RegionName_EN=array("Quebec","Nova Scotia","New Brunswick","Newfoundland","British Columbia","Alberta","Manitoba","Northwest Territories","Nunavut","Ontario","Prince Edward Island","Saskatchewan","Yukon Territory");
  9. $RegionName_FR=array("Québec","Nouvelle-Écosse","Nouveau-Brunswick","Terre-Neuve/Labrador","Colombie-Britanique","Alberta","Manitoba","Territoire du Nord Ouest","Nunavut","Ontario","Ile-du-Prince-Édouard","Saskatchewan","Territoire du Yukon");
  10.  
  11. echo "<TABLE>";
  12. echo "<TR>";
  13. echo "<TD><B>Nom de la province/territoire</B></TD>";
  14. echo "<TD><B>Taxe 1</B></TD>";
  15. echo "<TD><B>Taxe 2</B></TD>";
  16. echo "<TD><B>Taux</B></TD>";
  17. echo "<TD><B>1$</B></TD>";
  18. echo "<TD><B>15$</B></TD>";
  19. echo "<TD><B>44,95$</B></TD>";
  20. echo "<TD><B>100$</B></TD>";
  21. echo "</TR>";
  22. for($I=0;$I<count($RegionName_FR);$I++) {
  23.     echo "<TR>";
  24.     echo "<TD>" . $RegionName_FR[$I] . "</TD>";
  25.     echo "<TD>" . $TaxName1[$I] . ":" . $TaxRate1[$I] . "%</TD>";
  26.     if($TaxName2[$I]=="") {
  27.         echo "<TD> </TD>";
  28.     } else {
  29.         echo "<TD>" . $TaxName2[$I] . ":" . $TaxRate2[$I] . "%</TD>";
  30.     }
  31.     echo "<TD>";
  32.     switch($Compute[$I]) {
  33.         case "S": //Séparé
  34.             $Tax = $TaxRate1[$I]+$TaxRate2[$I];
  35.             break;
  36.         case "C": //Composé
  37.             $Tax = $TaxRate1[$I]+(($TaxRate2[$I]*(100+$TaxRate1[$I]))/100);
  38.             break;
  39.     }
  40.     echo strval($Tax) . "%";
  41.     echo "</TD>";
  42.     echo "<TD>" . strval(1*(1+($Tax/100))) . "$</TD>";
  43.     echo "<TD>" . strval(15*(1+($Tax/100))) . "$</TD>";
  44.     echo "<TD>" . strval(44.95*(1+($Tax/100))) . "$</TD>";
  45.     echo "<TD>" . strval(100*(1+($Tax/100))) . "$</TD>";
  46.     echo "</TR>";
  47. }
  48. echo "</TABLE>";
  49. ?>

on obtiendra le résultat suivant :

Nom de la province/territoireTaxe 1Taxe 2Taux1$15$44,95$100$
QuébecTPS:6%TVQ:7.5%13.95%1.1395$17.0925$51.220525$113.95$
Nouvelle-ÉcosseTVH:14% 14%1.14$17.1$51.243$114$
Nouveau-BrunswickTVH:14% 14%1.14$17.1$51.243$114$
Terre-Neuve/LabradorTVH:14% 14%1.14$17.1$51.243$114$
Colombie-BritaniqueTPS:6%TVP:7%13%1.13$16.95$50.7935$113$
AlbertaTVH:6% 6%1.06$15.9$47.647$106$
ManitobaTPS:6%TVP:7%13%1.13$16.95$50.7935$113$
Territoire du Nord OuestTVH:6% 6%1.06$15.9$47.647$106$
NunavutTVH:6% 6%1.06$15.9$47.647$106$
OntarioTPS:6%TVP:8%14%1.14$17.1$51.243$114$
Ile-du-Prince-ÉdouardTPS:6%TVP:10%16.6%1.166$17.49$52.4117$116.6$
SaskatchewanTPS:6%TVP:7%13%1.13$16.95$50.7935$113$
Territoire du YukonTVH:6% 6%1.06$15.9$47.647$106$

Voir également

Langage de programmation - ASP 3.0 - Gouvernement - Taxe de vente canadienne,
Langage de programmation - DB2 - Gouvernement - Taxe de vente canadienne,
Langage de programmation - Java - Gouvernement - Taxe de vente canadienne,
Langage de programmation - Oracle - Gouvernement - Taxe de vente canadienne,
Langage de programmation - Ruby - Gouvernement - Taxe de vente canadienne,
Langage de programmation - Sybase - Gouvernement - Taxe de vente canadienne

Dernière mise à jour : Mardi, le 20 octobre 2009