Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

CONVERSION : OCTETS, KILO, MEGA, TERA, ETC. ADDITION ET SOUSTRACTION


Information sur la source

Catégorie :Divers Niveau : Initié Date de création : 18/05/2003 Date de mise à jour : 21/05/2003 03:50:25 Vu / téléchargé: 9 925 / 166

Note :
Aucune note

Commentaire sur cette source (3)
Ajouter un commentaire et/ou une note

Description

Cliquez pour voir la capture en taille normale
Module qui utilise une déclaration de type de données pour les différentes catégories de volume binaire. Octets, kilo, méga. etc.
Un démo est inclus pour vos testes.
Le module contient une fonction d'initialisation/mise à zéro, une fonction de conversion, une d'addition et une de soustraction.
((( Correction à la fonction de soustraction ))).
 

Source

  • ' module de base. Utiliser le démo pour l'utiliser.
  • Option Explicit
  • ' Module de conversion et calcul d'espace
  • ' vbfrance, dpouliot
  • ' inspiré d'un code de < vbfrance, vbtom > merci
  • Public Type t_OKMG ' structure des valeurs par catégorie
  • val(8) As Double ' nombre octet, kilo, etc...
  • nom(8) As String ' nom de la valeur
  • top_ref As Integer ' si 3 = nombre en Giga illimité
  • ' si 4 = nombre en tera illmité, etc...
  • End Type
  • ' **********************************************************
  • ' initialisation et mise à zéro d'une structure
  • Sub fnc_init_OKMG(okmg As t_OKMG)
  • Dim cc As Integer
  • While cc < 8
  • okmg.val(cc) = 0
  • cc = cc + 1
  • Wend
  • okmg.top_ref = 4 ' 4 = le plus haut résultat en Tera
  • ' cette valeur pourra être plus grande que 1024
  • ' nom des carégories
  • okmg.nom(0) = "octet(s)" ' Octet
  • okmg.nom(1) = "Ko" ' Kilo Octets
  • okmg.nom(2) = "Mo" ' méga Octets
  • okmg.nom(3) = "Go" ' Giga Octets
  • okmg.nom(4) = "To" ' tera Octets
  • okmg.nom(5) = "Po" ' penta Octets
  • okmg.nom(6) = "Eo" ' exa Octets
  • okmg.nom(7) = "Zo" ' zetta Octets
  • okmg.nom(8) = "Yo" ' yotta Octets
  • End Sub
  • ' **********************************************************
  • ' cette fonction prend toute les valeurs de ces catégories
  • ' et les ramenent en multiple de 1024 par catégorie
  • Function fnc_okmg_cnv(okmg As t_OKMG) As t_OKMG
  • Dim p_grand As Double
  • Dim cc As Integer
  • Screen.MousePointer = 11
  • p_grand = 1073741824 ' 1Go, valeur max utiliser pour éviter dépassement de capacité mémoire
  • While cc < okmg.top_ref
  • While okmg.val(cc) >= p_grand
  • okmg.val(cc) = okmg.val(cc) - p_grand
  • okmg.val(cc + 1) = okmg.val(cc + 1) + (p_grand / 1024)
  • Wend
  • okmg.val(cc + 1) = okmg.val(cc + 1) + (okmg.val(cc) \ 1024) ' entier de la division
  • okmg.val(cc) = okmg.val(cc) Mod 1024 ' le mod donne erreur
  • cc = cc + 1
  • Wend
  • fnc_okmg_cnv = okmg
  • Screen.MousePointer = 0
  • End Function
  • ' **********************************************************
  • Function fnc_okmg_add(okmg_1 As t_OKMG, okmg_2 As t_OKMG) As t_OKMG
  • Dim cc As Integer
  • Dim okmg_3 As t_OKMG
  • fnc_init_OKMG okmg_3
  • While cc <= okmg_3.top_ref
  • okmg_3.val(cc) = okmg_1.val(cc) + okmg_2.val(cc)
  • cc = cc + 1
  • Wend
  • okmg_3 = fnc_okmg_cnv(okmg_3)
  • fnc_okmg_add = okmg_3
  • End Function
  • ' **********************************************************
  • ' ATT. : ne pas faire de soustraction négative, pas traité
  • Function fnc_okmg_sous(okmg_1 As t_OKMG, okmg_2 As t_OKMG) As t_OKMG
  • Dim cc As Integer
  • Dim okmg_3 As t_OKMG
  • fnc_init_OKMG okmg_3
  • cc = 0
  • While cc < okmg_3.top_ref
  • If okmg_1.val(cc) < okmg_2.val(cc) Then
  • okmg_1.val(cc) = okmg_1.val(cc) + 1024
  • okmg_1.val(cc + 1) = okmg_1.val(cc + 1) - 1
  • End If
  • cc = cc + 1
  • Wend
  • cc = 0
  • While cc < okmg_3.top_ref
  • okmg_3.val(cc) = okmg_1.val(cc) - okmg_2.val(cc)
  • cc = cc + 1
  • Wend
  • okmg_3 = fnc_okmg_cnv(okmg_3)
  • fnc_okmg_sous = okmg_3
  • End Function
  • ' **********************************************************
' module de base. Utiliser le démo pour l'utiliser.
Option Explicit

' Module de conversion et calcul d'espace
' vbfrance, dpouliot
' inspiré d'un code de < vbfrance, vbtom > merci

Public Type t_OKMG      ' structure des valeurs par catégorie
    val(8) As Double    ' nombre octet, kilo, etc...
    nom(8) As String    ' nom de la valeur
    top_ref As Integer  ' si 3 = nombre en Giga illimité
                        ' si 4 = nombre en tera illmité, etc...
End Type

' **********************************************************
                    ' initialisation et mise à zéro d'une structure
Sub fnc_init_OKMG(okmg As t_OKMG)
Dim cc As Integer

While cc < 8
    okmg.val(cc) = 0
    cc = cc + 1
Wend
                            
okmg.top_ref = 4            ' 4 = le plus haut résultat en Tera
                            ' cette valeur pourra être plus grande que 1024

                   ' nom des carégories
okmg.nom(0) = "octet(s)"    ' Octet
okmg.nom(1) = "Ko"          ' Kilo Octets
okmg.nom(2) = "Mo"          ' méga Octets
okmg.nom(3) = "Go"          ' Giga Octets
okmg.nom(4) = "To"          ' tera Octets
okmg.nom(5) = "Po"          ' penta Octets
okmg.nom(6) = "Eo"          ' exa Octets
okmg.nom(7) = "Zo"          ' zetta  Octets
okmg.nom(8) = "Yo"          ' yotta Octets
End Sub
' **********************************************************


    ' cette fonction prend toute les valeurs de ces catégories
    ' et les ramenent en multiple de 1024 par catégorie
Function fnc_okmg_cnv(okmg As t_OKMG) As t_OKMG
Dim p_grand  As Double
Dim cc As Integer

Screen.MousePointer = 11
p_grand = 1073741824    ' 1Go, valeur max utiliser pour éviter dépassement de capacité mémoire

While cc < okmg.top_ref
    While okmg.val(cc) >= p_grand
        okmg.val(cc) = okmg.val(cc) - p_grand
        okmg.val(cc + 1) = okmg.val(cc + 1) + (p_grand / 1024)
    Wend
    
    okmg.val(cc + 1) = okmg.val(cc + 1) + (okmg.val(cc) \ 1024)  ' entier de la division
    okmg.val(cc) = okmg.val(cc) Mod 1024          ' le mod donne erreur

    cc = cc + 1
Wend

fnc_okmg_cnv = okmg
Screen.MousePointer = 0
End Function
' **********************************************************

Function fnc_okmg_add(okmg_1 As t_OKMG, okmg_2 As t_OKMG) As t_OKMG
Dim cc As Integer
Dim okmg_3 As t_OKMG

fnc_init_OKMG okmg_3

While cc <= okmg_3.top_ref
    okmg_3.val(cc) = okmg_1.val(cc) + okmg_2.val(cc)
    cc = cc + 1
Wend

okmg_3 = fnc_okmg_cnv(okmg_3)
fnc_okmg_add = okmg_3
End Function
' **********************************************************

        ' ATT. : ne pas faire de soustraction négative, pas traité
Function fnc_okmg_sous(okmg_1 As t_OKMG, okmg_2 As t_OKMG) As t_OKMG
Dim cc As Integer
Dim okmg_3 As t_OKMG

fnc_init_OKMG okmg_3

cc = 0
While cc < okmg_3.top_ref
    If okmg_1.val(cc) < okmg_2.val(cc) Then
        okmg_1.val(cc) = okmg_1.val(cc) + 1024
        okmg_1.val(cc + 1) = okmg_1.val(cc + 1) - 1
    End If
    cc = cc + 1
Wend

cc = 0
While cc < okmg_3.top_ref
    okmg_3.val(cc) = okmg_1.val(cc) - okmg_2.val(cc)
    cc = cc + 1
Wend

okmg_3 = fnc_okmg_cnv(okmg_3)
fnc_okmg_sous = okmg_3
End Function
' **********************************************************

 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Commentaires et avis

signaler à un administrateur
Commentaire de max12 le 18/05/2003 01:46:26 administrateur CS

Il en manque :P

signaler à un administrateur
Commentaire de dpouliot le 18/05/2003 03:07:10

Salut max12, si tu parles de "Penta", met le "top_ref" à 5 dans la fonction "fnc_init_OKMG". Les résultats s'afficherons en "Penta" aussi.
La valeur peut aller à 6 "exa", etc... Ça commence à être du volume...
Si c'est un autre "P", dans le TYPE augmenter l'indice à 9 et dans la routine d'initialisation faire "while cc &lt; 9". Ajouter le nom de la catégorie dans "fnc_init_OKMG", "okmg.nom(9) = "LeNom" et voilà une catégorie de plus, un autre multiple de 1024. Les traitements s'y adapterons, souf pour l'affichage dans le démo.

signaler à un administrateur
Commentaire de max12 le 19/05/2003 19:05:28 administrateur CS

Heuu je disait sa en blague ;) Quoique ce sera utile dans le futur puisque les disques durs deviennent de plus en plus gros et perfectionner.

Ajouter un commentaire



Nos sponsors

Sondage...

CalendriCode

Septembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
2930     

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,23 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.