IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

 C Discussion :

nombre de ligne dans un fichier


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut nombre de ligne dans un fichier
    Bonjour a tous !
    J'aimerai trouver une fontion simple qui retourne le nombre de lignes dans un fichier , ou bien qui affiche ce nombre de lignes en utilisant la fonction "fgets"


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    #include <stdio.h>
     
    int nb_lignes (FILE *fp)
    {
      int n=0, c;
     
      while ((c = fgetc(fp)) != EOF)
      {
        if (c == '\n')
        {
          n++;
        }
      }
      return n;
    }
    cette methode fonctionnne bien mais elle pose de probleme de vitesse d'exécution. car j'ai un fichier de plus de 1GO!!
    merci

  2. #2
    Expert éminent
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 393
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 393
    Par défaut
    Le problème, c'est que la fonction fgets() fait pratiquement la même chose en interne, donc je doute qu'on puisse vraiment faire plus vite...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  3. #3
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    merci Médinoc, avec un fichier de taille de plus de1Go , ca va rester 1 journée pour lire seulement le texte

  4. #4
    Invité(e)
    Invité(e)
    Par défaut
    Bonjour

    Lire un gros bloc de données et compter les '\n' dedans ne serait il pas un peu plus rapide ?

    Il faudra quand même parcourir le texte caractère par caractère, mais cette fois depuis la mémoire... Le défaut, c'est que sa perd en simplicité.

    EDIT:

    Dans ce gout :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    29
    #include <stdio.h>
    #include <stdlib.h>
    #define BUF_SIZE 1024
     
    int nb_lignes_2(FILE * fp)
    {
        int lc = 0;
        int read;
        char *cur;
        char *end;
        long pos = ftell(fp);
        fseek(fp, 0, SEEK_SET);
     
        char buf[BUF_SIZE];
        for (;;) {
            read = fread(buf, 1, BUF_SIZE, fp);
            end = buf + read;
            for (cur = buf; cur != end; ++cur) {
                if ('\n' == *cur) {
                    ++lc;
                }
            }
            if (read != BUF_SIZE) {
                break;
            }   
        }
        fseek(fp, pos, SEEK_SET);
        return lc;
    }
    Dernière modification par Invité(e) ; 10/09/2008 à 15h47. Motif: confusion dans les paramètres de fread

  5. #5
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    Citation Envoyé par mabu Voir le message
    Bonjour

    Lire un gros bloc de données et compter les '\n' dedans ne serait il pas un peu plus rapide ?

    Il faudra quand même parcourir le texte caractère par caractère, mais cette fois depuis la mémoire...
    merci Mabu, sincerement je comprends pas trop ce que tu veux dire
    tu peux m'expliquer un peu plus stp
    merci

  6. #6
    Invité(e)
    Invité(e)
    Par défaut
    Citation Envoyé par cyrine Voir le message
    merci Mabu, sincerement je comprends pas trop ce que tu veux dire
    tu peux m'expliquer un peu plus stp
    merci
    Voir mon EDIT.

  7. #7
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    Peut être que mapper le fichier en mémoire et compte les '\n' en mémoire sera plus rapide (voire la fonction mmap()) ?

    Juste une idée comme cela
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  8. #8
    Membre Expert
    Inscrit en
    Décembre 2004
    Messages
    1 478
    Détails du profil
    Informations forums :
    Inscription : Décembre 2004
    Messages : 1 478
    Par défaut
    Si tu as Linux, tu peux essayer un wc -l sur ton fichier. Ca te donnera une idee des performances que tu peux atteindre (i.e. je doute que tu puisses faire mieux!).

  9. #9
    Expert éminent
    Avatar de Emmanuel Delahaye
    Profil pro
    Retraité
    Inscrit en
    Décembre 2003
    Messages
    14 512
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2003
    Messages : 14 512
    Par défaut
    Citation Envoyé par cyrine Voir le message
    merci Médinoc, avec un fichier de taille de plus de1Go , ca va rester 1 journée pour lire seulement le texte
    Euh, tu as fait l'essai ?

    100 Mo :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
     
    #include <stdio.h>
     
    static void make_file (char const *fname, long nb_lines, long line_len)
    {
       FILE *fp = fopen (fname, "w");
     
       if (fp != NULL)
       {
          long lin;
          for (lin = 0; lin < nb_lines; lin++)
          {
             long col;
             for (col = 0; col < line_len; col++)
             {
                static char const alpha[] = "0123456789 "
                   "abcdefghijklmnopqrstuvwxyz" "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
                int c = alpha[col  % (sizeof alpha - 1)];
                fputc (c, fp);
             }
             fputc ('\n', fp);
     
          }
          fclose (fp);
       }
       else
       {
          perror (fname);
       }
    }
     
    long count_lines (char const *fname)
    {
       long count = 0;
     
       FILE *fp = fopen (fname, "r");
     
       if (fp != NULL)
       {
          int c;
     
          while ((c = fgetc (fp)) != EOF)
          {
             if (c == '\n')
             {
                count++;
             }
          }
          fclose (fp);
       }
       else
       {
          perror (fname);
       }
       return count;
    }
     
    int main (void)
    {
       make_file ("data.txt", 10000, 10000);
       long count = count_lines ("data.txt");
     
       printf ("count = %ld\n", count);
       return 0;
    }
    35 secondes, génération comprise

    Lecture seule :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    count = 10000
     
    Process returned 0 (0x0)   execution time : 17.466 s
    Press any key to continue.
    Faire des mesures avant de s'imagner des choses...

  10. #10
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    Citation Envoyé par Emmanuel Delahaye Voir le message
    Euh, tu as fait l'essai ?
    ah non pas encore , un fichier avec 500 milles lignes !!!

    imagine

  11. #11
    Membre éclairé Avatar de étoile de mer
    Profil pro
    Étudiant
    Inscrit en
    Avril 2007
    Messages
    978
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2007
    Messages : 978
    Par défaut
    comme ca il ma affiché rien
    je vois pas où est le probleme
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    #include <stdio.h>
    #include <stdlib.h>
     #define PATH "c:\\essai.txt"
     
     
    void main()
    {
         FILE * F;
         int res;
         int i;
    char buffer[1024];
    int nb_read;
    	F=fopen(PATH,"r"); 
    res = 0;
    while ((nb_read = read(F, buffer, 1023)))
    {
     i = 0;
     buffer[nb_read] = '\0';
     while (buffer[i] != '\0')
      {
       if (buffer[i] == '\n')
        res++;
       i++;
      }
    }
    fprintf("%i", res);
    fclose(F); 
    }
    help pliz

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. nombre de lignes dans un fichier .txt
    Par marieo dans le forum VB 6 et antérieur
    Réponses: 4
    Dernier message: 31/10/2007, 15h22
  2. Compter le nombre de ligne dans un fichier
    Par amine_en_france dans le forum Scripts/Batch
    Réponses: 2
    Dernier message: 31/05/2007, 17h19
  3. Nombre de lignes dans un fichier
    Par theshark85 dans le forum C
    Réponses: 48
    Dernier message: 05/05/2006, 10h15
  4. [Fichier] Nombre de ligne dans un fichier texte
    Par NewSer dans le forum Entrée/Sortie
    Réponses: 7
    Dernier message: 10/11/2004, 16h58
  5. Réponses: 2
    Dernier message: 02/03/2004, 19h38

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo