begin process at 2010 02 10 12:16:52
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Maths

 > CONVERSION LITTÉRALE D'UN NOMBRE ENTIER OU FLOTTANT

CONVERSION LITTÉRALE D'UN NOMBRE ENTIER OU FLOTTANT


 Information sur la source

Note :
6,5 / 10 - par 2 personnes
6,50 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10
Catégorie :Maths Classé sous :nombre, lettre, conversion, chiffre, littéral Niveau :Débutant Date de création :04/02/2007 Date de mise à jour :05/02/2007 20:51:08 Vu / téléchargé :10 036 / 776

Auteur : japee

Ecrire un message privé
Ce membre participe au partage de revenus publicitaires
Commentaire sur cette source (16)
Ajouter un commentaire et/ou une note


 Description

Cliquez pour voir la capture en taille normale
Affiche en toutes lettres un nombre avec ou sans virgule, avec son unité (monétaire, mesure, etc...).

Bien qu'il existe d'autres sources sur le sujet, il m'a paru intéressant de publier la mienne pour plusieurs raisons :

- elle gère bien les règles grammaticales concernant les adjectifs numéraux cardinaux tels que définies par le Bescherelle,
- elle prend en compte le singulier et le pluriel,
- la grandeur des nombres n'est limitée que par l'étendue du type utilisé pour les définir,
- elle me semble suffisemment robuste et capable de rendre un réel service, bien qu'elle puisse être grandement améliorée.
- c'est moi "que je" l'ai faite...

Vous trouverez en prime une fonction perso qui trouve ici son utilité :

function StrToFloatDef(S: string; Def: Extended): Extended;

Une impression de déjà vu quelque part ???
C'est normal.
Cette fonction qui s'applique à un nombre réel, est semblable à la fonction StrToIntDef pour les nombre entiers.

Bien que je me réserve d'améliorer tout ça, il me semble que ça peut rendre service en l'état.

Source

  • unit Num2Let;
  • interface
  • uses Math, SysUtils;
  • function NumericToLetters(Num: Int64): string; overload;
  • function NumericToLetters(Num: Extended; const Sep: string = 'virgule'): string; overload;
  • implementation
  • function NumericToLetters(Num: Int64): string;
  • const
  • N0_19: array[0..19] of string =
  • ('zéro','un','deux','trois','quatre','cinq','six','sept','huit','neuf', 'dix',
  • 'onze','douze','treize','quatorze','quinze','seize','dix-sept','dix-huit','dix-neuf');
  • N20_60: array[2..6] of string =
  • ('vingt','trente','quarante','cinquante','soixante');
  • Separator: array[Boolean] of string = ('-', ' et ');
  • Pluriel: array[Boolean] of string = ('', 's');
  • DIX : Int64 = 10;
  • CENT : Int64 = 100;
  • MILLE : Int64 = 1000;
  • MILLION : Int64 = 1000000;
  • MILLIARD : Int64 = 1000000000;
  • var
  • NDizaines, NCentaines, NMilliers, NMillions, NMilliards: Int64;
  • begin
  • if Num > 999999999 then
  • begin
  • NMilliards := Num div MILLIARD;
  • if Num mod MILLIARD = 0 then
  • Result := NumericToLetters(NMilliards)
  • + ' milliard'
  • + Pluriel[NMilliards > 1]
  • else
  • Result := NumericToLetters(NMilliards)
  • + ' milliard' + Pluriel[NMilliards > 1] + ' '
  • + NumericToLetters(Num - (NMilliards) * MILLIARD);
  • end
  • else
  • case Num of
  • 0..19: Result := N0_19[Num];
  • 20..69:
  • begin
  • NDizaines := Num div DIX;
  • if Num mod DIX = 0 then // if (Num in [20,30,40,50,60]) then
  • Result := N20_60[NDizaines]
  • else
  • Result := N20_60[NDizaines]
  • + Separator[Num mod DIX = 1]
  • + N0_19[Num - NDizaines * DIX];
  • end;
  • 70..79: Result := 'soixante' + Separator[Num mod DIX = 1] + N0_19[Num - 60];
  • 80: Result := 'quatre-vingts';
  • 81..99: Result := 'quatre-vingt-' + N0_19[Num - 80];
  • 100: Result := 'cent';
  • 101..199: Result := 'cent ' + NumericToLetters(Num - CENT);
  • 200..999:
  • begin
  • NCentaines := Num div CENT;
  • if Num mod CENT = 0 then
  • Result := N0_19[NCentaines] + ' cents'
  • else
  • Result := N0_19[NCentaines] + ' cent ' + NumericToLetters(Num - NCentaines * CENT);
  • end;
  • 1000: Result := 'mille';
  • 1001..1999: Result := 'mille ' + NumericToLetters(Num - MILLE);
  • 2000..999999:
  • begin
  • NMilliers := Num div MILLE;
  • if Num mod MILLE = 0 then
  • Result := NumericToLetters(NMilliers) + ' mille'
  • else
  • Result := NumericToLetters(NMilliers) + ' mille '
  • + NumericToLetters(Num - NMilliers * MILLE);
  • end;
  • 1000000..999999999:
  • begin
  • NMillions := Num div MILLION;
  • if Num mod MILLION = 0 then
  • Result := NumericToLetters(NMillions)
  • + ' million' + Pluriel[NMillions > 1]
  • else
  • Result := NumericToLetters(NMillions)
  • + ' million' + Pluriel[NMillions > 1] + ' '
  • + NumericToLetters(Num - NMillions * MILLION);
  • end;
  • end;
  • end;
  • { ni la plus élégante ni la plus rapide des solutions, mais efficace }
  • procedure SeparateIntDec(Value: Extended; var IntPart, DecPart: Int64;
  • const N: Byte = 2);
  • var
  • S, sIntPart, sDecPart: string;
  • P: Byte;
  • begin
  • S := FloatToStr(Value); // uses SysUtils
  • P := Pos(DecimalSeparator, S);
  • if P = 0 then
  • begin
  • IntPart := Int64(Trunc(Value));
  • DecPart := 0;
  • end
  • else
  • begin
  • sIntPart := Copy(S, 1, Pos(DecimalSeparator, S) - 1);
  • sDecPart := Copy(S, Pos(DecimalSeparator, S) + 1, 2);
  • IntPart := StrToIntDef(sIntPart, 0);
  • if Length(sDecPart) = 2 then
  • DecPart := StrToInt64Def(sDecPart, 0)
  • else
  • DecPart := StrToInt64Def(sDecPart + '0', 0);
  • end;
  • end;
  • { fonction très simplifiée, suffisante pour cet usage }
  • function PluralOf(const S: string; const Value: Extended): string;
  • const
  • P: array[False..True] of string = ('', 's');
  • NotAllowed = ['s', 'x', 'z'];
  • var
  • Plural: Boolean;
  • begin
  • Plural := (Abs(Value) >= 2) and (S <> 'virgule') and not(S[Length(S)] in NotAllowed);
  • Result := Format('%s%s', [S, P[Plural]]);
  • end;
  • function NumericToLetters(Num: Extended; const Sep: string = 'virgule'): string;
  • var
  • IntPart, DecPart: Int64;
  • Separator: string;
  • begin
  • SeparateIntDec(Num, IntPart, DecPart);
  • Separator := Format(' %s ', [PluralOf(Sep, Num)]);
  • Result := NumericToLetters(IntPart) + Separator + NumericToLetters(DecPart);
  • end;
  • end.
  • -------------------------------------------------------------------------------
  • function StrToFloatDef(S: string; Def: Extended): Extended;
  • var
  • Code: Integer;
  • begin
  • if DecimalSeparator <> '.' then // uses SysUtils
  • S := StringReplace(S, DecimalSeparator, '.', []);
  • Val(S, Result, Code);
  • if Code <> 0 then
  • Result := Def;
  • end;
unit Num2Let;

interface

uses Math, SysUtils;

function NumericToLetters(Num: Int64): string; overload;
function NumericToLetters(Num: Extended; const Sep: string = 'virgule'): string; overload;

implementation

function NumericToLetters(Num: Int64): string;
const
  N0_19: array[0..19] of string =
  ('zéro','un','deux','trois','quatre','cinq','six','sept','huit','neuf', 'dix',
  'onze','douze','treize','quatorze','quinze','seize','dix-sept','dix-huit','dix-neuf');
  N20_60: array[2..6] of string =
  ('vingt','trente','quarante','cinquante','soixante');
  Separator: array[Boolean] of string = ('-', ' et ');
  Pluriel: array[Boolean] of string = ('', 's');
  DIX      : Int64 = 10;
  CENT     : Int64 = 100;
  MILLE    : Int64 = 1000;
  MILLION  : Int64 = 1000000;
  MILLIARD : Int64 = 1000000000;
var
  NDizaines, NCentaines, NMilliers, NMillions, NMilliards: Int64;
begin
  if Num > 999999999 then
  begin
    NMilliards := Num div MILLIARD;
    if Num mod MILLIARD = 0 then
      Result := NumericToLetters(NMilliards)
                + ' milliard'
                + Pluriel[NMilliards > 1]
    else
      Result := NumericToLetters(NMilliards)
                + ' milliard' + Pluriel[NMilliards > 1] + ' '
                + NumericToLetters(Num - (NMilliards) * MILLIARD);
  end
  else
  case Num of
    0..19: Result := N0_19[Num];
    20..69:
    begin
      NDizaines := Num div DIX;
      if Num mod DIX = 0 then // if (Num in [20,30,40,50,60]) then
        Result := N20_60[NDizaines]
      else
        Result := N20_60[NDizaines]
                  + Separator[Num mod DIX = 1]
                  + N0_19[Num - NDizaines * DIX];
    end;
    70..79: Result := 'soixante' + Separator[Num mod DIX = 1] + N0_19[Num - 60];
    80:     Result := 'quatre-vingts';
    81..99: Result := 'quatre-vingt-' + N0_19[Num - 80];
    100:    Result := 'cent';
    101..199: Result := 'cent ' + NumericToLetters(Num - CENT);
    200..999:
    begin
      NCentaines := Num div CENT;
      if Num mod CENT = 0 then
        Result := N0_19[NCentaines] + ' cents'
      else
        Result := N0_19[NCentaines] + ' cent ' + NumericToLetters(Num - NCentaines * CENT);
    end;
    1000: Result := 'mille';
    1001..1999: Result := 'mille ' + NumericToLetters(Num - MILLE);
    2000..999999:
    begin
      NMilliers := Num div MILLE;
      if Num mod MILLE = 0 then
        Result := NumericToLetters(NMilliers) + ' mille'
      else
        Result := NumericToLetters(NMilliers) + ' mille '
                  + NumericToLetters(Num - NMilliers * MILLE);
    end;
    1000000..999999999:
    begin
      NMillions := Num div MILLION;
      if Num mod MILLION = 0 then
        Result := NumericToLetters(NMillions)
                  + ' million' + Pluriel[NMillions > 1]
      else
        Result := NumericToLetters(NMillions)
                  + ' million' + Pluriel[NMillions > 1] + ' '
                  + NumericToLetters(Num - NMillions * MILLION);
    end;
  end;
end;

{ ni la plus élégante ni la plus rapide des solutions, mais efficace }
procedure SeparateIntDec(Value: Extended; var IntPart, DecPart: Int64;
  const N: Byte = 2);
var
  S, sIntPart, sDecPart: string;
  P: Byte;
begin
  S := FloatToStr(Value);   // uses SysUtils
  P := Pos(DecimalSeparator, S);
  if P = 0 then
  begin
    IntPart := Int64(Trunc(Value));
    DecPart := 0;
  end
  else
  begin
    sIntPart := Copy(S, 1, Pos(DecimalSeparator, S) - 1);
    sDecPart := Copy(S, Pos(DecimalSeparator, S) + 1, 2);
    IntPart  := StrToIntDef(sIntPart, 0);
    if Length(sDecPart) = 2 then
      DecPart := StrToInt64Def(sDecPart, 0)
    else
      DecPart := StrToInt64Def(sDecPart + '0', 0);
  end;
end;

{ fonction très simplifiée, suffisante pour cet usage }
function PluralOf(const S: string; const Value: Extended): string;
const
  P: array[False..True] of string = ('', 's');
  NotAllowed = ['s', 'x', 'z'];
var
  Plural: Boolean;
begin
  Plural := (Abs(Value) >= 2) and (S <> 'virgule') and not(S[Length(S)] in NotAllowed);
  Result := Format('%s%s', [S, P[Plural]]);
end;

function NumericToLetters(Num: Extended; const Sep: string = 'virgule'): string;
var
  IntPart, DecPart: Int64;
  Separator: string;
begin
  SeparateIntDec(Num, IntPart, DecPart);
  Separator := Format(' %s ', [PluralOf(Sep, Num)]);
  Result := NumericToLetters(IntPart) + Separator + NumericToLetters(DecPart);
end;

end.

-------------------------------------------------------------------------------

function StrToFloatDef(S: string; Def: Extended): Extended;
var
  Code: Integer;
begin
  if DecimalSeparator <> '.' then   // uses SysUtils
    S := StringReplace(S, DecimalSeparator, '.', []);
  Val(S, Result, Code);
  if Code <> 0 then
    Result := Def;
end;

 Conclusion

Compilable à partir de D4.
N'hésitez pas à me signaler les vilains bugs.

 Fichier Zip

Les Membres Club peuvent télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip


 Historique

04 février 2007 13:30:13 :
Suppression d'une variable superflue.
05 février 2007 20:27:05 :
Correction d'un bug se produisant quand le paramétrage système du séparateur décimal est le point (merci à Lucien pour me l'avoir fait remarquer). Utilisation de StrToInt64Def() dans la procedure SeparateIntDec() afin de rester cohérent avec la valeur à traiter sur 64 bits (merci à WhiteHippo pour le conseil).
05 février 2007 20:51:08 :
Retouche mineure dans le blabla de présentation.

 Sources du même auteur

Source avec Zip Source avec une capture DEPLACER LES ITEMS D'UNE LISTBOX VERS UNE AUTRE PAR DRAG AND...
Source avec Zip Source avec une capture DÉMINEUR UTILISANT UNE TDRAWGRID ET AVEC LEQUEL ON PEUT TRIC...
Source avec Zip Source avec une capture SIGNIFICATION DES CODES D'ERREUR DE L'API WIN32 - UTILISATIO...
Source avec Zip Source avec une capture TPULSEBUTTON - RÉPÉTITION PROGRESSIVE D'UN EVENT PENDANT ONK...
Source avec Zip Source avec une capture PUCE S'AJUSTANT EN FONCTION DE LA LARGEUR D'UN LABEL

 Sources de la même categorie

Source avec Zip Source avec une capture CONVERTISSEUR D'UN NOMBRE DÉCIMAL EN BINAIRE ET HEXADECIMAL par ludokk
Source avec Zip Source avec une capture PREMIER OU PAS? par ludokk
Source avec Zip Source avec une capture CONJECTURE DU CARRÉ DES FACTEURS par Bacterius
Source avec Zip Source avec une capture GÉNÉRATEUR DE NOMBRES PSEUDO-ALÉATOIRES par Bacterius
Source avec Zip Source avec une capture ALGORITHME DE HASH LEA par Bacterius

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture CONVERSION LITTÉRALE D' 1 NOMBRE EN PORTUGAIS par MAURICIO
Source avec Zip CONVERSION MONTANT MONÉTAIRE, NOMBRE ET DATE EN CHAINE TOUT ... par qoprek
Source avec Zip Source avec une capture [UNIT] ROMANUTILS, TOUT POUR CONVERTIR LES CHIFFRES ROMAINS ... par f0xi
Source avec Zip CONVERSION CHIFFRES EN LETTRES ARABES MISE À JOUR par blanc76
Source avec Zip Source avec une capture TROUVEZ LES MOTS DE 9 LETTRES AU JEU DES «CHIFFRES ET DES LE... par grandvizir

Commentaires et avis

Commentaire de japee le 04/02/2007 02:40:30 administrateur CS

En attendant la mise à jour (demain), vous pouvez enlever cette variable :
RDecPart: Extended;
à la ligne 96.
Elle est complètement inutile.
Bonne nuit aux couche-tard... ^^

Commentaire de lucien le 05/02/2007 09:16:40

Bonjour Japee,
je ne comprends pas...
Si je saisis 126.25
j'obtiens «cent ving six virgule zéro»
comme si les décimales n'étaient pas prises en compte ?
Si tu trouves avant moi,
Merci de nous le dire!
Lucien

Commentaire de japee le 05/02/2007 09:31:07 administrateur CS

Salut Lucien.

Je viens d'essayer la version que j'ai postée, on ne sait jamais.
Voici le copier-coller de ce que j'obtiens si je saisis "126.25" :
"cent vingt-six virgule vingt-cinq",
et pareil si je saisis "126,25".
Alors ?
Tu m'as foutu les jetons, là...

Commentaire de lucien le 05/02/2007 14:51:13

Désolé pour l'horreur...
mais je ne trouve pas de solution !
Il faut que je poursuive mon enquête...
Dans l'editfloat, si je tape 12525,
la réponse est correcte
si je déplace le curseur avant la deuxième décimale, soit 125.ou,25 la réponse est zéro virgule zéro !!!
Il y a un vice quelque part...
Est-ce que mon XP pro et mon D6 pro peuvent avoir une influence ?
Lucien

Commentaire de lucien le 05/02/2007 15:01:09

Dans "SeparateIntDec"
la fonction pos() renvoie zéro
même s'il y a une décimale ?
Quelqu'un en imagine la raison ?
Lucien

Commentaire de lucien le 05/02/2007 17:38:21

Je crois qu'il y a un pb de logique, dans la fonction StrToFloatDef ?
DecimalSeparator est une variable environnementale indépendante du prog.
Si elle est sur Point (comme chez moi) au lieu de virgule (ce qui semble être le cas sur ta machine ?) la chaine d'éditfloat
peut avoir une virgule ou un point. Dans ce dernier cas, elle ne sera pas modifiée, d'où une erreur dans la procédure d'analyse SeparateIntDec qui recherche une Virgule....:)
Lucien

Commentaire de japee le 05/02/2007 18:49:05 administrateur CS

Le problème n'est pas dans StrToFloatDef qui remplit parfaitement son contrat.

Il faut modifier la procedure SeparateIntDec() dans unit Num2Let,
en remplaçant les 3 lignes d'instructions où il est fait mention de ',' par DecimalSeparator, ce qui donne :

procedure SeparateIntDec(Value: Extended; var IntPart, DecPart: Int64;
  const N: Byte = 2);
var
  S, sIntPart, sDecPart: string;
  P: Byte;
begin
  S := FloatToStr(Value);   // uses SysUtils
  P := Pos(DecimalSeparator, S);
  if P = 0 then
  begin
    IntPart := Int64(Trunc(Value));
    DecPart := 0;
  end
  else
  begin
    sIntPart := Copy(S, 1, Pos(DecimalSeparator, S) - 1);
    sDecPart := Copy(S, Pos(DecimalSeparator, S) + 1, 2);
    IntPart  := StrToIntDef(sIntPart, 0);
    if Length(sDecPart) = 2 then
      DecPart  := StrToIntDef(sDecPart, 0)
    else
      DecPart  := StrToIntDef(sDecPart + '0', 0);
  end;
end;

Je corrigerai plus tard, ce soir sans doute.

Merci de ta vigilance.

Il n'est pas inutile de toute manière d'introduire une fonction de filtrage de la validité de saisie (nombreux sources sur le site, voir l'excellente source de Cirec et son Edit magique).

En effet, je ne vais pas à fond dans ce sens, ça sera l'objet d'améliorations de cette unité, mais ça n'est pas le fond du propos. l'Intérêt tient surtout à l'utilisation de la récursion pour accomplir la conversion des chiffres aux lettres.

A plus.

japee

Commentaire de japee le 05/02/2007 18:50:43 administrateur CS

Euh... pardon, je voulais dire la récursitude, lol ^^

Commentaire de WhiteHippo le 05/02/2007 19:13:29

Bonsoir Japee

Il me semble que tu devrais remplacer dans ta procédure SeparateIntDec les appels à "StrToIntDef" par des appels à "StrToInt64Def" afin de profiter pleinement des valeurs sur 64 bits.

Cordialement.

Commentaire de japee le 05/02/2007 19:23:30 administrateur CS

Salut WhiteHippo,

Oh oui, bien vu !
C'est vrai qu'elle est pas jolie, jolie, cette procedure, je ne l'aime pas trop, alors je l'ai un peu négligée...

Je rectifierai dans la prochaine mise à jour.

Merci.

Commentaire de MAURICIO le 06/02/2007 10:54:33

Salut Japee,

pas si simple comme fonction!
J'ai fait la même il y a longtemps et voici les paramètres que j' ai utilisé, ça pourrait t' aider à améliorer ta fonction (je traduis les paramètres) :

function REAL_PARA_LETRAS(Valeur: Double; NbDecimaux: Word;
                          Prefix_Intier: String; Separateur_Decimaux: String;
                          Prefixo_Decimaux: String; Forcer_Decimaux: Boolean;
                          Decimaux_Zeros_A_gauche: Boolean): String;

Ainsi, 2.06 peut être ecrit selon les paramètres:
"deux euros et six centimes"
"deux virgule zero six centimètres" (Decimaux_Zeros_A_gauche=true)
etc ...

Ainsi, 4.0 peut être ecrit selon les paramètres:
"quatre euros"  (Forcer_Decimaux=false)
"quatre euros et zero centime" (Forcer_Decimaux=true)
etc ...

L' idée est de pouvoir utiliser la fonction pour les euros ou des mesures parce que :
2 virgule six <> 2 virgule zero six

A+

Commentaire de MAURICIO le 06/02/2007 10:56:56

J' ai oublié de préciser que ma fonction renvoit le résultat en portugais et non pas en français!
Mais ceux qui me connaissent avaient compris :)
A+

Commentaire de bongenie le 07/02/2007 00:53:13

Personnellement, je préfère gérer le problème de la virgule de façon autoritaire dès l'appui de la touche, à savoir :
procedure TForm1.edFloatOnKeyPress(Sender: TObject; var Key: Char);
begin
if key=',' then key:='.';
end;

Les problèmes compliqués ont souvent des réponses simples ;-) (bien sûr si on veut vraiment voir la vrai virgule c'est un autre problème)

Commentaire de lucien le 07/02/2007 07:36:17

Pour Japi,
Je vois que tu viens de déposer une mise à jour que je vais découvrir...J'aurais aimé qu'elle contienne (peut-être est-ce le cas ?) une option pour choisir le nombre de décimales...Il est parfois utile d'en avoir plus de deux...
Merci,
Lucien

Commentaire de japee le 20/02/2007 17:52:36 administrateur CS

Salut Mauricio,

Je prends note de tes suggestions pour une évolution future de mon code. Merci pour tes commentaires qui sont constructifs et utiles, comme d'habitude.
Je suis allé faire un tour du côté de la source que tu as publiée sur le sujet, mais n'ai pas eu le temps de la tester. Je le ferai dès que possible.
Quand à la limace visqueuse qui m'a collé un 3 sans laisser la moindre explication, je ne lui dirai pas ce que je pense de ce genre de comportement : il ne comprendrait sans doute pas plus qu'il ne comprend quelque chose à la programmation.

Commentaire de Jean-Pierre le 10/07/2009 17:35:09 10/10

Bonjour,

Ce petit mot d'encouragement, car je trouve absolument dég******** la note de 3 apportée à ce source.

Un code comme ça mérite au moins le triple, voilà qui est dit !

Un 10 et bravo Japee !

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

conversion en arabe de chiffre en lettre sous delphi5 [ par azerouk ] SVP je voudrai codes de conversion en arabe de chiffre en lettre merci .sous delphi 5 Convertir Chiffre en Lettre avec QuickReport [ par slim59 ] Slt. J'utilise QuickReport pour imprimer mes factures, mais je n'arrive pas à convertir le montant en chiffre, en Lettre.(j'utilise DBaseIII+)Merci+++ chiffre en lettre dans un état de sortie d'une facture en quickreprot [ par saidajerry ] Bonjour tout le monde, s'il y a quelqu'un qui peut m'aider et je le remercie mille fois d'avance.mon problème et que j'ai édité un état de sortie avec chiffre en lettre [ par vrachid ] bj a tousy a til un moyen de convertir un chiffre en sa position numérique dans l'alphabet?par exemple si je tape 1 dans un edit j'aurai un A dans l'a programme de conversion d'un nombre Hexadécimal en un nombre BCD [ par racimo1985 ] Bonjour tout le monde, je programme en assembleur sur un micro intel 8085 Je recherche un programme que me permettrait de convertir un nombre Hexadéci Conversion nombre en texte [ par ndjioua ] &gt; Salut je cherche une fonction qui me permettait de convertir un nombre (exp: 1523) en son équivalent écrit sous forme de text (Mille cinq cent v Compter avec SQL [ par roud59 ] Bonjour (Bonsoir) &#224; vous tous. Ma question concerne plut&#244;t SQL que delphi, mais je n'ai pas trouv&#233; ce language sur CodeS-SourceS. Quelq conversion de type de variables [ par RV57000 ] Bonjour, mon probl&#234;me est que je cherche &#224; d&#233;finir la lettre d'un lecteur dans un DriveListBox.La variable contenant cette lettre est r convertir les prix de chiffre en lettre [ par karimaitouares ] je suis coincé sur un point qui me semble important je cherche un algorithme a integrer dans mon application qui me permet de convertir les prix de le La lettre majuscule d'un mot en premier? [ par yeho ] Salut! Je sais que la meilleur manière d'être aidé dans Delphifr.com c'est d'exhiber aussi sa volonté de recherche.Mais j'ai une procedure que je ve


Nos sponsors


Sondage...

CalendriCode

Février 2010
LMMJVSD
1234567
891011121314
15161718192021
22232425262728

Consulter la suite du CalendriCode

 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), 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

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,264 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales