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

Shell et commandes GNU Discussion :

Trier les lignes d'un fichier texte


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    324
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2012
    Messages : 324
    Points : 13
    Points
    13
    Par défaut Trier les lignes d'un fichier texte
    Bonsoir tout le monde,
    j'ai un fichier qui contient des longueur de mask d'adresses IP. la forme est la suivante
    22
    23
    8
    ...
    je veux écrire un script shell qui me permet de trier les longueur de mask en de compter leurs occurences: c'est à dire il me renvoie combiens existe t-il de /22, de /23...
    le scriprs est très facile à réaliser si je connais à priori les catégorie des mask fugurant dans mon fichier. mais malheureusement je n'ai pas cette information car le fichier est très très grand et je ne peux pas m'amuser à compter les catégorie qui le compose.

    pourriez vous me donnez une piste pour commencez.

    merci beacoup

  2. #2
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 550
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 550
    Points : 19 383
    Points
    19 383
    Par défaut
    Bonjour,

    a priori, pour trier un fichier, c'est sort
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sort -n fichier | uniq -c
    ...
    ?

    info coreutils !
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    324
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2012
    Messages : 324
    Points : 13
    Points
    13
    Par défaut
    voila j'ai réussi à écrire un petir script mais le résultat qu'il retourne est faux
    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
    while [ ! -f $1 ]
    do
     echo "on attend que le fichier maskLength soit prêt"
    sleep 5
    done
     
    while read line
    do
      if [ ! -f $line ]
      then touch $line
     mask=$(expr $mask  + 1)
      echo "$mask" > $line
    elif [ -f $1 ]
    then mask=$(expr $mask  + 1)
    echo "$mask" > $line
    fi
    done < $1
    $1=test et contien( trois /12, un /48 et un /23)
    à l'éxécution j'i les trois fichiers crées correctement mais 12 contient 5 et non pas 3
    48 contient 2 à la place de 1 et /23 contient 1)

    comment régler ça merci

  4. #4
    Modérateur
    Avatar de N_BaH
    Profil pro
    Inscrit en
    Février 2008
    Messages
    7 550
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2008
    Messages : 7 550
    Points : 19 383
    Points
    19 383
    Par défaut
    pour des fichiers très volumineux, il faut privilégier awk, qui, en plus d'un temps de traitement très nettement amélioré par rapport à un script shell, dispose dans toutes ses versions de tableaux associatifs.
    ça te permettrait d'avoir un tableau tableauAsso, dont les indices seraient le contenu de la ligne, et dont la valeur serait incrémentée.
    Tutoriel Awk
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  5. #5
    Membre à l'essai
    Femme Profil pro
    Étudiant
    Inscrit en
    Août 2012
    Messages
    324
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2012
    Messages : 324
    Points : 13
    Points
    13
    Par défaut
    Merci beaucoup, je lirai le tutoriel.

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 101
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Développeur informatique en retraite

    Informations forums :
    Inscription : Avril 2008
    Messages : 2 101
    Points : 5 849
    Points
    5 849
    Par défaut
    Bonjour,

    ton 'elif' peut avantageusement être remplacé par un 'else'.

    Est-il normal que tu utilises un seul compteur $mask pour tous les fichiers?
    Je ne suis pas sûr d'avoir tout compris, mais il me semble que si le fichier $line n'existe pas, il faudrait l'initialiser avec 1 et que s'il existe, il faudrait incrémenter la valeur qu'il contient...
    tout ça peut être fait en ram (donc beaucoup plus rapidement) avec les tableaux associatifs de awk (cf. post N_BaH).

    Le seul avantage qu'on pourrait imaginer à le faire avec des fichiers est qu'on peut consulter des résultats intermédiaires pendant que l'exécution se déroule (si ça prend beaucoup de temps), et qu'en cas d'interruption, on peut avoir un résultat partiel...

  7. #7
    Rédacteur

    Avatar de ok.Idriss
    Homme Profil pro
    IS Consultant
    Inscrit en
    Février 2009
    Messages
    5 220
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : IS Consultant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Février 2009
    Messages : 5 220
    Points : 19 452
    Points
    19 452
    Par défaut
    Bonsoir.

    Pour t'aiguiller davantage, voici un exemple de choses très simples que tu peux faire avec awk et les tableaux associatifs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    [idriss@hp-dv6:~]$ cat test.txt 
    192.168.1.2/24
    192.168.1.2/23
    189.100.200.1/8
    192.168.1.3/24
    [idriss@hp-dv6:~]$ awk -F "/" '{if($2 in array){array[$2]++}else{array[$2]=1}} END {for (i in array){print i" : "array[i]" occurrences"}}' test.txt
    8 : 1 occurrences
    23 : 1 occurrences
    24 : 2 occurrences
    Tu peux t'inspirer de cette structure et l'adapter à ton besoin (notamment la partie calcul de longueur du masque et la partie trie par longueur).

    Cordialement,
    Idriss

Discussions similaires

  1. Réponses: 1
    Dernier message: 24/12/2013, 14h13
  2. Réponses: 21
    Dernier message: 17/12/2012, 15h38
  3. Boucle qui parcourt tout les ligne d'un fichier text
    Par accro-macro dans le forum VB 6 et antérieur
    Réponses: 12
    Dernier message: 10/05/2007, 20h21
  4. Réponses: 2
    Dernier message: 19/09/2006, 21h34
  5. Réponses: 3
    Dernier message: 26/04/2004, 12h51

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