Publicité
+ Répondre à la discussion
Affichage des résultats 1 à 2 sur 2
  1. #1
    Membre à l'essai
    Inscrit en
    juillet 2003
    Messages
    78
    Détails du profil
    Informations forums :
    Inscription : juillet 2003
    Messages : 78
    Points : 21
    Points
    21

    Par défaut Manipulation de chaînes de caractères

    à partir des sources même de ce site (§8 http://c.developpez.com/sources/c/?page=sommaire), des fonctions de manipulation de chaînes de caractères :

    le code source original de remplacement d'une sous-chaîne (vieux) par une autre (nouveau) dans une chaîne de caractères (source) :
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    int RemplacerFragment (char *source, const char *vieux, const char *nouveau)
    {
      char *original = source;
      char temp[4096];
      int ancienne_long = strlen (vieux);
      int i, j, k, place = -1;
      for (i = 0; source[i] && (place == -1); ++i)
        for (j = i, k = 0; source[j] == vieux[k]; j++, k++)
          if (!vieux[k+1])
            place = i;
      if (place != -1) 
      {
        for (j=0; j<place; j++)
          temp[j] = source[j];
        for (i=0; nouveau[i]; i++, j++)
          temp[j] = nouveau[i];
        for (k = place + ancienne_long; source[k]; k++, j++)
          temp[j] = source[k];
        temp[j] = 0;
        for (i=0; source[i] = temp[i]; i++)
          ;
      }
      return place;
    }
    une digression du code précédent de remplacement d'une sous-chaîne (vieux) dans une chaîne (source) par une nouvelle sous-chaîne (nouveau) si cette sous-chaîne est encadrée par une chaîne de séparation (separateur)
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    int RemplacerFragment (char *source, const char *vieux, const char *nouveau, const char *separateur)
    {
      char *original = source;
      char temp[4096];
      int ancienne_long = strlen (vieux);
      int i, j, k, place = -1;
      for (i = 0; source[i] && (place == -1); ++i)
        for (j = i, k = 0; source[j] == vieux[k]; j++, k++)
          if (!vieux[k+1] && (i==0 || source[i-1]==*separateur) && (source[j+1]== *separateur || source[j+1]=='\n'))
            place = i;
      if (place != -1) 
      {
        for (j=0; j<place; j++)
          temp[j] = source[j];
        for (i=0; nouveau[i]; i++, j++)
          temp[j] = nouveau[i];
        for (k = place + ancienne_long; source[k]; k++, j++)
          temp[j] = source[k];
        temp[j] = 0;
        for (i=0; source[i] = temp[i]; i++)
          ;
      }
      return place;
    }
    une fonction qui permet d'ôter la fin de chaîne d'une chaîne (source) à partir de la position d'une sous-chaîne (vieux)
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    int RetirerCommentaire (char *source, const char *vieux)
    {
      char *original = source;
      char temp[4096];
      int ancienne_long = strlen (vieux);
      int i, j, k, place = -1;
      for (i = 0; source[i] && (place == -1); ++i)
        for (j = i, k = 0; source[j] == vieux[k]; j++, k++)
          if (!vieux[k+1])
            place = i;
      if (place != -1)
      {
        for (j=0; j<place; j++)
          temp[j] = source[j];
        temp[j] = 0;
        for (i=0; source[i] = temp[i]; i++)
          ;
      }
      return place;
    }
    Une fonction qui permet de remplacer une sous-chaîne non précisée par une nouvelle (nouveau) si elle est encadrée par deux sous-chaînes (vieux1 et vieux 2)
    Code :
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    int RetirerCommentaire (char *source, const char *vieux1, const char *nouveau, const char *vieux2)
    {
      char *original = source;
      char temp[4096];
      int ancienne_long = strlen (vieux1);
      int i = 0, j = 0, k = 0, place1 = -1, place2 = -1;
      for (i = 0; source[i] && (place1 == -1); ++i)
        for (j = i, k = 0; source[j] == vieux1[k]; j++, k++)
          if (!vieux1[k+1] )
            place1 = i;
      for (i = j; source[i] && (place2 == -1); ++i)
        for (j = i, k = 0; source[j] == vieux2[k]; j++, k++)
          if (!vieux2[k+1] )
            place2 = j;
      if (place1 != -1 && place2 != -1) 
      {
        for (j=0; j<place1; j++)
          temp[j] = source[j];
        for (i=0; nouveau[i]; i++, j++)
          temp[j] = nouveau[i];
        for (k = ++place2 ; source[k]; k++, j++)
          temp[j] = source[k];
        temp[j] = 0;
        for (i=0; source[i] = temp[i]; i++)
          ;
      }
      return place1 != -1 && place2 != -1 ;
    }

  2. #2
    Rédacteur
    Avatar de gege2061
    Inscrit en
    juin 2004
    Messages
    5 845
    Détails du profil
    Informations personnelles :
    Âge : 31

    Informations forums :
    Inscription : juin 2004
    Messages : 5 845
    Points : 10 504
    Points
    10 504

    Par défaut

    Je vais regarder ça à tête reposée.

    pour ton aide.

Liens sociaux

Règles de messages

  • Vous ne pouvez pas créer de nouvelles discussions
  • Vous ne pouvez pas envoyer des réponses
  • Vous ne pouvez pas envoyer des pièces jointes
  • Vous ne pouvez pas modifier vos messages
  •