Accueil > > > GRAPHIQUE EN BARRES (FAÇON EXCEL)
GRAPHIQUE EN BARRES (FAÇON EXCEL)
Information sur la source
Description
J'avais besoin d'un petit bout de codes pour générer des barres en compta, n'ayant rien trouvé à ce sujet voilà chose faite avec ces quelques lignes qui vous généreront un graphique assez simple mais très parlant.
Source
- <%
-
- ' === Déclarations =============================================
- dim tab_achats ' 1=fournisseur ; 2=ttl
- dim tab_temp ' idem tab_achats pour le tri
- dim ttl_max: ttl_max=0 ' valeur max retenue
- dim largeur_tab: largeur_tab = 600 ' largeur du tableau à l'affichage
- dim clr_cel ' déclaration de la couleur de cellule
- dim i,j,k,flag_etat
-
- ' === Affichage ===============================================
- ' remplissage du Tableau
- redim tab_achats(5,2)
- tab_achats (1,1) = "Pierre"
- tab_achats (1,2) = 100
- tab_achats (2,1) = "Paul"
- tab_achats (2,2) = 20
- tab_achats (3,1) = "Jacques"
- tab_achats (3,2) = 40.50
- tab_achats (4,1) = "Titi"
- tab_achats (4,2) = 70
- tab_achats (5,1) = "Roméo"
- tab_achats (5,2) = 80
-
- ' Récupération du montant Max
- for i=1 to UBound(tab_achats)
- if tab_achats(i,2) > ttl_max then ttl_max=tab_achats(i,2)
- next
-
- range_donnees ' range les données du montant le plus fort au plus faible
- trace_graphe ' trace le graphique
-
-
- ' === Fonctions Internes =========================================
- Function range_donnees
- ' tri par ordre croissant
- j=1: redim tab_temp(1,2)
- do while j<(UBound(tab_achats)+1)
- flag_etat = true
- for i=(j+1) to UBound(tab_achats)
- if tab_achats(j,2)<tab_achats(i,2) then
- ' échange des données
- for k=1 to 2
- tab_temp(1,k)=tab_achats(j,k)
- next
- for k=1 to 2
- tab_achats(j,k)=tab_achats(i,k)
- next
- for k=1 to 2
- tab_achats(i,k)=tab_temp(1,k)
- next
- flag_etat = false
- exit for
- end if
- next
- if flag_etat then j=j+1
- loop
- End Function
-
- Function trace_graphe
- Response.Write "<br><table align=center width="& largeur_tab &" border=0 cellpadding=0 cellspacing=0>"
- for i=1 to UBound(tab_achats)
- Randomize: clr_cel = Cint(255*(Rnd+1-1)) & Cint(255*(Rnd+1-1)) & Cint(255*(Rnd+1-1)) ' génération couleur Hexa
- Response.Write "<tr>" &_
- "<td width=200><font face='Verdana' size=2>"& tab_achats(i,1) &" </font></td>" &_
- "<td>" &_
- "<table width='"& Cint(100*(tab_achats(i,2)/ttl_max)) &"%' border=0 cellpadding=0 cellspacing=0>" &_
- "<tr bgcolor='#"& clr_cel &"'><td><img src='vide.gif' width='100%' height=10 border=0 alt='"& FormatNumber(tab_achats(i,2),2) &" ?'></td></tr>" &_
- "</table>" &_
- "</td>" &_
- "</tr>"
- Response.Write "<tr>" &_
- "<td><img src='vide.gif' height=5 border=0></td>" &_
- "<td><img src='vide.gif' height=5 border=0></td>" &_
- "</tr>"
- next
- Response.Write "</table>"
- End Function
-
- %>
<%
' === Déclarations =============================================
dim tab_achats ' 1=fournisseur ; 2=ttl
dim tab_temp ' idem tab_achats pour le tri
dim ttl_max: ttl_max=0 ' valeur max retenue
dim largeur_tab: largeur_tab = 600 ' largeur du tableau à l'affichage
dim clr_cel ' déclaration de la couleur de cellule
dim i,j,k,flag_etat
' === Affichage ===============================================
' remplissage du Tableau
redim tab_achats(5,2)
tab_achats (1,1) = "Pierre"
tab_achats (1,2) = 100
tab_achats (2,1) = "Paul"
tab_achats (2,2) = 20
tab_achats (3,1) = "Jacques"
tab_achats (3,2) = 40.50
tab_achats (4,1) = "Titi"
tab_achats (4,2) = 70
tab_achats (5,1) = "Roméo"
tab_achats (5,2) = 80
' Récupération du montant Max
for i=1 to UBound(tab_achats)
if tab_achats(i,2) > ttl_max then ttl_max=tab_achats(i,2)
next
range_donnees ' range les données du montant le plus fort au plus faible
trace_graphe ' trace le graphique
' === Fonctions Internes =========================================
Function range_donnees
' tri par ordre croissant
j=1: redim tab_temp(1,2)
do while j<(UBound(tab_achats)+1)
flag_etat = true
for i=(j+1) to UBound(tab_achats)
if tab_achats(j,2)<tab_achats(i,2) then
' échange des données
for k=1 to 2
tab_temp(1,k)=tab_achats(j,k)
next
for k=1 to 2
tab_achats(j,k)=tab_achats(i,k)
next
for k=1 to 2
tab_achats(i,k)=tab_temp(1,k)
next
flag_etat = false
exit for
end if
next
if flag_etat then j=j+1
loop
End Function
Function trace_graphe
Response.Write "<br><table align=center width="& largeur_tab &" border=0 cellpadding=0 cellspacing=0>"
for i=1 to UBound(tab_achats)
Randomize: clr_cel = Cint(255*(Rnd+1-1)) & Cint(255*(Rnd+1-1)) & Cint(255*(Rnd+1-1)) ' génération couleur Hexa
Response.Write "<tr>" &_
"<td width=200><font face='Verdana' size=2>"& tab_achats(i,1) &" </font></td>" &_
"<td>" &_
"<table width='"& Cint(100*(tab_achats(i,2)/ttl_max)) &"%' border=0 cellpadding=0 cellspacing=0>" &_
"<tr bgcolor='#"& clr_cel &"'><td><img src='vide.gif' width='100%' height=10 border=0 alt='"& FormatNumber(tab_achats(i,2),2) &" ?'></td></tr>" &_
"</table>" &_
"</td>" &_
"</tr>"
Response.Write "<tr>" &_
"<td><img src='vide.gif' height=5 border=0></td>" &_
"<td><img src='vide.gif' height=5 border=0></td>" &_
"</tr>"
next
Response.Write "</table>"
End Function
%>
Conclusion
RAS, toutes est expliqué dans les codes.
have a good luck ..., Zeb13.
Sources du même auteur
Sources de la même categorie
Commentaires et avis
|
Derniers Blogs
TECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLETECHDAYS PARIS 2012 : SYSTEM CENTER SERVICE MANAGER 2012 VUE D'ENSEMBLE par ROMELARD Fabrice
Speakers: Julien Marechal, Gautier Confiant, Sébastien MEYER La session débute par le positionnement de la solution System Center par rapport aux concepts d'organisation ITIL. Le portail du catalogue de se...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : PLEINIèRE SECOND JOURTECHDAYS PARIS 2012 : PLEINIèRE SECOND JOUR par ROMELARD Fabrice
Après une première journée dédiée aux développeurs, cette seconde journée est dédiée au monde des entreprises et de ses applications. Ainsi, cette pleinière est dédiée à faire un 360 de l'évolution des applications Business aux demandes ac...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : RETOUR D'EXPéRIENCE SUR LA MISE EN PLACE D'UN CLOUD PRIVéTECHDAYS PARIS 2012 : RETOUR D'EXPéRIENCE SUR LA MISE EN PLACE D'UN CLOUD PRIVé par ROMELARD Fabrice
Speaker : Guillaume Rochette Cette session est dédiée à fournir le retour sur la mise en place d'un cloud privé (IaaS) par Osiatis pour son compte ou celui de ses clients. Ce projet s'est déroulé sur 4 mois et a permis de faire évoluer...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice TECHDAYS PARIS 2012 : COMMENT SHAREPOINT A SAUVé MES TECHDAYSTECHDAYS PARIS 2012 : COMMENT SHAREPOINT A SAUVé MES TECHDAYS par ROMELARD Fabrice
Speakers : Lionel Limozin et Alain Marty La session commence par une découverte de SharePoint à travers la mise en place d'un environnement SharePoint pour la gestion des Sessions animées par BeWise. Le besoin est très ba...
Cliquez pour lire la suite de l'article par ROMELARD Fabrice PERSPECTIVE 3.0 POUR SILVERLIGHT 5.0PERSPECTIVE 3.0 POUR SILVERLIGHT 5.0 par odewit
Je viens de publier la version 3.0 de Perspective pour Silverlight, qui regroupe un portage sous Silverlight 5.0 des fonctionnalités de Perspective 2.0, le framework 3D de haut-niveau introduit récemment et de nouveaux exemples de code. En voici la li...
Cliquez pour lire la suite de l'article par odewit
Logiciels
Academy System (17.2.1.0)ACADEMY SYSTEM (17.2.1.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Easy-Planning (1.0.0.1)EASY-PLANNING (1.0.0.1)Basé sur les mêmes principes que MyPlanning, Easy-Planning permet de créer des plannings sous la ... Cliquez pour télécharger Easy-Planning COLLECTOR PLUS (3.00B)COLLECTOR PLUS (3.00B)COLLECTOR PLUS version 3.00B est un logiciel utilisant une base de données alimentée par :
- L... Cliquez pour télécharger COLLECTOR PLUS PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO (V7.4)PONAMEDIA TV DEVIENS HELLLOOO FLASH
LA TV SUR VOTRE ORDINATEUR.
Toute une plateforme Multi... Cliquez pour télécharger PONAMEDIA PREMIUM - HELLLOOO FLASH DEMO LettresFaciles 2011 (8.0.0.1)LETTRESFACILES 2011 (8.0.0.1)LettresFaciles est un logiciel facilitant la création et la rédaction de lettres types.
Son inte... Cliquez pour télécharger LettresFaciles 2011
|