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 :

Tri d'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 Tri d'un fichier
    Bonjour à tous
    je possede un fichier sous cette forme consitutué des regles , et j'aimerai bie le trier par ordre decroissant selon la valeur entre parenthese , mais le souci là c'est que j'aimerai trier chaque bloc à part (u bloc : ensemble de regles qui ont les meme mots à gauche de la fleche
    Donc selon ce fichier je fais le tri de ca seulemnt ensemble
    calendriers et-->a(1.815442e-01)
    calendriers et-->i(6.696747e-02)
    calendriers et-->so(6.696747e-02
    et puis de ca
    aborde un-->but(1.481987e-02)
    aborde un-->what(2.133122e-01)
    aborde un-->ground(1.481987e-02)
    aborde un-->time(1.481987e-02)
    et puis du reste
    voilà la structure de fichier
    calendriers et-->a(1.815442e-01)
    calendriers et-->i(6.696747e-02)
    calendriers et-->so(6.696747e-02)
    aborde un-->but(1.481987e-02)
    aborde un-->what(2.133122e-01)
    aborde un-->ground(1.481987e-02)
    aborde un-->time(1.481987e-02)
    a recours-->pay(4.242722e-01)
    a recours-->including(4.242722e-01)
    a recours-->expect(9.018633e-01)
    je seche d'idée
    Une idée svp?
    merci

  2. #2
    Nouveau candidat au Club
    Profil pro
    Inscrit en
    Février 2009
    Messages
    2
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2009
    Messages : 2
    Par défaut
    pas tres clair, mais bon

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk -F"(" '{printf "%s|%f\n", $0,substr($2,1,length($2)-1)}' monFicher | awk -F"-->" '{printf "%s|%s\n",$0, $1}' | sort -t"|" -k3 -k2.1rn | awk -F"|" '{print $1}'
    oups, suis hors sujet, on oublie, désolé

  3. #3
    Membre émérite Avatar de SofEvans
    Homme Profil pro
    Développeur C
    Inscrit en
    Mars 2009
    Messages
    1 084
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 36
    Localisation : France

    Informations professionnelles :
    Activité : Développeur C

    Informations forums :
    Inscription : Mars 2009
    Messages : 1 084
    Par défaut
    Ce que tu peux faire, c'est quelque chose dans ce gout la.

    Tu retiens en memoire les indice de depart et de fin d'un bloc.
    Puis, tu applique un algo de tri : qsort ou trie a bulle feront l'affaire.

    Tout ce que tu as a faire, c'est de recuperer le nombre entre parenthese pour l'algo de comparaison. Utilise fscanf ou fgets pour ca.

  4. #4
    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 SofEvans Voir le message
    Ce que tu peux faire, c'est quelque chose dans ce gout la.

    Tu retiens en memoire les indice de depart et de fin d'un bloc.
    Puis, tu applique un algo de tri : qsort ou trie a bulle feront l'affaire.

    Tout ce que tu as a faire, c'est de recuperer le nombre entre parenthese pour l'algo de comparaison. Utilise fscanf ou fgets pour ca.
    Merci SoftEvans, mais c'est pas evident de sauvegarder l'indice de fin de chaque bloc

  5. #5
    Expert confirmé

    Avatar de fearyourself
    Homme Profil pro
    Ingénieur Informaticien Senior
    Inscrit en
    Décembre 2005
    Messages
    5 121
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Ingénieur Informaticien Senior
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2005
    Messages : 5 121
    Par défaut
    Moi je ferai qq chose comme ca :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    /* Tant qu'il y a qq chose */
     
      /* Stocke les lignes d'un même bloc */
     
      /* Tri */
     
      /* Ecriture du bloc */
    Jc

  6. #6
    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

  7. #7
    Membre émérite
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Par défaut
    @svictor76 : On programme en C

    Si ta sortie est obligatoirement formatée comme tu dis tu peux faire un fscanf comme ça :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    #include <stdio.h>
     
    int main(void) {
    	char str[100] = "";
    	double n;
     
    	fscanf(stdin, "%[^(] %*c %le", str, &n);
     
    	printf("%s\n%e\n", str, n);
     
    	return 0;
    }
    Après à toi d'adapter le code

    Edit :
    J'ai oublié un bout
    Une fois tout ça chargé en mémoire tu utilises tout bêtement une fonction de tri (qsort ?) et, si tu le souhaite, tu réécris tout ça dans un fichier

  8. #8
    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 pour vos reponses, est ce que je charge le fichier dans un tableau ou non

  9. #9
    Membre émérite
    Avatar de Pouet_forever
    Profil pro
    Inscrit en
    Octobre 2009
    Messages
    671
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2009
    Messages : 671
    Par défaut
    Citation Envoyé par Pouet_forever Voir le message
    Une fois tout ça chargé en mémoire [...]
    Ca répond à ta question ?

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

Discussions similaires

  1. Optimiser le tri d'un fichier
    Par mejri dans le forum Algorithmes et structures de données
    Réponses: 2
    Dernier message: 13/11/2006, 09h56
  2. [VBA Excel Débutant] Tri d'un fichier Excel depuis Access
    Par elgringo2007 dans le forum Access
    Réponses: 3
    Dernier message: 07/08/2006, 16h21
  3. Tri d'un fichier
    Par Premium dans le forum C
    Réponses: 14
    Dernier message: 15/01/2006, 22h55
  4. tri d'un fichier texte
    Par ben127 dans le forum C
    Réponses: 7
    Dernier message: 23/12/2005, 20h03

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