begin process at 2010 02 10 11:22:38
  Trouver un code source :
 
dans
 
Accueil > 

Code

 > 

Texte

 > FONCTION RENVOYANT LE POURCENTAGE DE SIMILITUDE ENTRE 2 CHAINES

FONCTION RENVOYANT LE POURCENTAGE DE SIMILITUDE ENTRE 2 CHAINES


 Information sur la source

Note :
Aucune note
Catégorie :Texte Classé sous :comparaison, similitude, ressemblance Niveau :Débutant Date de création :18/08/2006 Date de mise à jour :18/08/2006 13:49:19 Vu :5 972

Auteur : qoprek

Ecrire un message privé
Site perso
Commentaire sur cette source (3)
Ajouter un commentaire et/ou une note

 Description

On peut être amener a effectuer une recherche de chaine sans être sûr de l'orthographe de la chaine recherchée. Cette fonction retourne un pourcentage de ressemblance entre 2 chaines, et ainsi vous pouvez fournir des résultats plus ou moins proche de la chaine recherchée. J'ai utilisé ce code dans un petit utilitaire de recherche de chaines dans des fichiers.

Source

  • // ----------------------------------------------------------------------------------------
  • Function ComparerChaines(s1,s2:String):Integer;
  • { Fonction comparaison chaînes de texte:
  • Entrée:
  • S1 = première chaîne a comparer, taille limitée a 2048 caractères
  • S2 = deuxième chaîne a comparer, taille limitée a 2048 caractères
  • Sortie:
  • INTEGER, de 0 a 100, % de ressemblance entre les 2 chaînes }
  • Var identiques, // Nombre de caractères identiques
  • p1,p2, // Indicateurs de position
  • l1,l2, // Longueurs des chaînes
  • pt, // Compteur de boucle
  • diff : Integer; // Facteur d égalisation
  • hstr : String; // Variable temporaire d échange des chaînes
  • test : Array [1..2048] Of Boolean; // Tableau d indicateur pour suivre les positions déjà testées
  • Begin
  • // Tester les longueurs et échanger si S1 est plus courte, on teste toujours par rapport a la chaîne la plus longue
  • If Length(s1)<Length(s2) Then Begin
  • hstr := s2;
  • s2 := s1;
  • s1 := hstr;
  • End;
  • // Stocker les longueurs des chaînes
  • l1 := Length(s1);
  • l2 := Length(s2);
  • // Une chaîne a vide ? alors la comparaison est de 0%
  • If (l1=0) Or (l2=0) Then
  • Result := 0
  • Else Begin
  • p1 := 1;
  • p2 := 1;
  • identiques := 0;
  • // Calculer le facteur d égalisation dépendant de la longueur de la chaîne, en général c est 1/3 de la longueur maximale
  • diff := Max(l1,l2) Div 3 + Abs(l1-l2);
  • // Initialiser le tableau de suivi
  • For pt := 1 To l1 Do
  • test[pt] := False;
  • // Parcours de la chaîne
  • Repeat
  • // Position testée ?
  • If Not test[p1] Then Begin
  • // Caractère identique ?
  • If (s1[p1]=s2[p2]) And (Abs(p1-p2)<=diff) Then Begin
  • test[p1] := True;
  • // Augmenter le compteur de caractères identiques
  • Inc(identiques);
  • // Positions suivantes
  • Inc(p1);
  • Inc(p2);
  • // Boucler
  • If p1>l1 Then p1:=1;
  • End Else Begin
  • Test[p1] := False;
  • Inc(p1);
  • // Boucler a la prochaine position de test si on arrive a la fin de la chaîne
  • If p1>l1 Then Begin
  • While (p1>1) And Not (test[p1]) Do
  • Dec(p1);
  • Inc(p2)
  • End;
  • End;
  • End Else Begin
  • Inc(p1);
  • // Boucler a la prochaine position de test si on arrive a la fin de la chaîne
  • If p1>l1 Then Begin
  • Repeat
  • Dec(p1);
  • Until (p1=1) Or test[p1];
  • Inc(p2);
  • End;
  • End;
  • Until p2>Length(s2);
  • // Calculer la valeur en pourcentage
  • Result := 100 * identiques Div l1;
  • End;
  • End;
// ----------------------------------------------------------------------------------------
Function ComparerChaines(s1,s2:String):Integer;
{ Fonction comparaison chaînes de texte:
  Entrée:
    S1 = première chaîne a comparer, taille limitée a 2048 caractères
    S2 = deuxième chaîne a comparer, taille limitée a 2048 caractères
  Sortie:
    INTEGER, de 0 a 100, % de ressemblance entre les 2 chaînes }
Var identiques,                        // Nombre de caractères identiques
    p1,p2,                             // Indicateurs de position
    l1,l2,                             // Longueurs des chaînes
    pt,                                // Compteur de boucle
    diff : Integer;                    // Facteur d égalisation
    hstr : String;                     // Variable temporaire d échange des chaînes
    test : Array [1..2048] Of Boolean; // Tableau d indicateur pour suivre les positions déjà testées
Begin
  // Tester les longueurs et échanger si S1 est plus courte, on teste toujours par rapport a la chaîne la plus longue
  If Length(s1)<Length(s2) Then Begin
    hstr := s2;
    s2   := s1;
    s1   := hstr;
  End;
  // Stocker les longueurs des chaînes
  l1 := Length(s1);
  l2 := Length(s2);
  // Une chaîne a vide ? alors la comparaison est de 0%
  If (l1=0) Or (l2=0) Then
    Result := 0
  Else Begin
    p1         := 1;
    p2         := 1;
    identiques := 0;
    // Calculer le facteur d égalisation dépendant de la longueur de la chaîne, en général c est 1/3 de la longueur maximale
    diff       := Max(l1,l2) Div 3 + Abs(l1-l2);
    // Initialiser le tableau de suivi
    For pt := 1 To l1 Do
      test[pt] := False;
    // Parcours de la chaîne
    Repeat
      // Position testée ?
      If Not test[p1] Then Begin
        // Caractère identique ?
        If (s1[p1]=s2[p2]) And (Abs(p1-p2)<=diff) Then Begin
          test[p1] := True;
          // Augmenter le compteur de caractères identiques
          Inc(identiques);
          // Positions suivantes
          Inc(p1);
          Inc(p2);
          // Boucler
          If p1>l1 Then p1:=1;
        End Else Begin
          Test[p1] := False;
          Inc(p1);
          // Boucler a la prochaine position de test si on arrive a la fin de la chaîne
          If p1>l1 Then Begin
            While (p1>1) And Not (test[p1]) Do
              Dec(p1);
            Inc(p2)
          End;
        End;
      End Else Begin
        Inc(p1);
        // Boucler a la prochaine position de test si on arrive a la fin de la chaîne
        If p1>l1 Then Begin
          Repeat
            Dec(p1);
          Until (p1=1) Or test[p1];
          Inc(p2);
        End;
      End;
    Until p2>Length(s2);
    // Calculer la valeur en pourcentage
    Result := 100 * identiques Div l1;
  End;
End;



 Historique

18 août 2006 13:49:20 :
Bogue de la colorisation syntaxique, si un simple quote (') est présent dans une ligne de simple commentaire (//)

 Sources du même auteur

Source avec Zip CONVERSION MONTANT MONÉTAIRE, NOMBRE ET DATE EN CHAINE TOUT ...

 Sources de la même categorie

Source avec Zip COMBINAISONS DE STRINGS par askil2000
Source avec Zip Source avec une capture RECONNAISSANCE DE CARACTÈRES (OCR) par Bacterius
Source avec Zip Source avec une capture NETTOYAGE AUTOMATIQUE DE NOMS DE FICHIERS par John Dogget
DISTANCE DE JARO-WINKLER par PoulpHunter
Source avec Zip BASE DE DONNÉE WIKI par thithony

 Sources en rapport avec celle ci

Source avec Zip Source avec une capture RECHERCHE / SUPPRESSION D'IMAGES EN DOUBLE (BASÉE SUR UNE CO... par Forman
Source avec Zip JEU DU MASTERMIND par atchoom7
Source avec Zip BINCOMP - COMPAREUR DE FICHIERS BINAIRE par DelphiCool

Commentaires et avis

Commentaire de flo160fr le 19/08/2006 12:11:10

Ton code a l'air intéressant, je le regarderai plus en détaille en rentrant de vaccance...
Il va surment m'être utile pour la recherche dans les fichiers d'aide

Bonne continuation ;)

Commentaire de f0xi le 21/08/2006 02:28:20 administrateur CS

pour eviter les bugs de colorisation il faut mettre les commentaires entre {} et non //

Commentaire de gbourgeois0019 le 11/11/2007 20:01:30

Le code marche super bien si les deux chaines diffèrent a leurs extrémité droite. Par contre si on change seulement la premiere lettre, on a automatiquement un resultat de 0 %.

 Ajouter un commentaire


Discussions en rapport avec ce code source dans le forum

Comparaison de string [ par aaleex ] Bjour a tous!J'aimerais savoir si il est possible de comparer si une string en contient une autre?Dans le genre : If CetteString est dans CelleLA then problème comparaison reel sous delphi 5.0 [ par momolino ] Bonjour,En fait, je suis en train de finir une application débuté sous delphi 5.0. Dans celle-ci je suis amené à faire pas mal de comparaison entre ré [probleme]comparaison de mot de passe, suis-je si mauvais? [ par budylove ] salut a tous pour mon auto-formation on m'a demandé de realiser un module de password. je sais il y a plein de truc la dessus dans le forum mais ce n' Comparaison de chaînes de caractères [ par John Dogget ] Bonsoir à tous.Je cherche une fonction me permettant de trouver si une chaîne S2 se trouve dans une chaîne S1, le tout sans respect de la casse (si po Comparaison impossible ... [ par EutcheX ] Bonsoir &#224; tous, Voil&#224;, depuis un moment je suis bloqu&#233; sur ce bout de code ... : Lorsque je met ceci : 'if (R1 = 'VALEUR') and (R2 = Comparaison de StringList [ par Dezouille ] Voila le sujet,J'ai 2 fichiers textes que j'ai monter dans 2 TStringList diff&#233;rentes&nbsp;(ListeFichier1, ListeFichier2)&nbsp;avec environ 70000 Comparaison [ par pablor44 ] Bonjour,donc voil&#224;, mon probl&#232;me est assez simple : j'ai un tableau remplis d'entier compris entre et 0 et 255, et je voudrais trouver l'ent problème de comparaison d'image en HLS. [ par richardsocrier ] comparaison de deux images bitmap [ par kamicaz2002 ] aidez moi sur la comparaison de deux images bmp si elle sont simelaire ou bien non. notre images sources et l'autre sont deux images de main sur un f comment accelerer la recherche de la semilarite entre deux images dans une grande base de données imades [ par kamicaz2002 ] voila je cherche accelerer le temps de recherche d'une image dans une BDD d'images...j'ai utilisé la methode de la correlation pour faire la comparais


Nos sponsors


Sondage...

Comparez les prix

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 : 0,811 sec (4)

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