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 :

Tri des lignes d'un fichier et consultation


Sujet :

Shell et commandes GNU

  1. #21
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 286
    Points : 12 743
    Points
    12 743
    Par défaut
    je ne suis pas sure de la sortie voulu, mais peut-être ce sed :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed "s/.*\(0x[^']*\)[^0-9]*\([0123456789\.e+]*\).*/\1:\2/;t;d" fichier
    En gardant les guillemets, sinon ça ne fonctionnera pas car je cherche une quote.
    Cordialement.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    ok.

    et, quelle est cette commande ?
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    Citation Envoyé par disedorgue Voir le message
    je ne suis pas sure de la sortie voulu, mais peut-être ce sed :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed "s/.*\(0x[^']*\)[^0-9]*\([0123456789\.e+]*\).*/\1:\2/;t;d" fichier
    En gardant les guillemets, sinon ça ne fonctionnera pas car je cherche une quote.
    oui, c'est largement mieux que la litanie de sed de BeepBeep
    mais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n "s/.*\(0x[^']*\)[^0-9]*\([0123456789\.e+]*\).*/\1:\2/p" fichier
    pourquoi t;d ?
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  4. #24
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 286
    Points : 12 743
    Points
    12 743
    Par défaut
    t-> si le s/.../.../ qui précède est vrai on va à la fin de la sequence pour passer à une prochaine ligne, donc le d n'est pas exécuté et donc si le substitue n'est pas fait, le d se fait.
    Cordialement.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    curieux.
    si il n'y a pas de correspondance avec le motif dans la partie gauche, le p n'est pas exécuté !
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  6. #26
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 286
    Points : 12 743
    Points
    12 743
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    curieux.
    si il n'y a pas de correspondance avec le motif dans la partie gauche, le p n'est pas exécuté !
    moqueur...

    Comme on dit: "Tous les chemins mènent au rhum"

    Cordialement.

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  8. #28
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 286
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur intégration
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Décembre 2012
    Messages : 4 286
    Points : 12 743
    Points
    12 743
    Par défaut
    Cadeau:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    $ cat /tmp/bob.txt 
    { candidates:
       { '0x02683507aF2C6b07421D1eA96594D7b87198e4AB': { capacity: 3.9065102e+23, status: 'OK' },
         '0x0294FFDE40972F8E5902aA855ecF967c04DEDD82': { capacity: 3.916795e+22, status: 'KO' },
         '0x05B6D0B939EA98ad3B34a44dFEc000821Fc14158': { capacity: 3.3262529e+23, status: 'OK' },
         '0x085D3799e83aaD45693ca8F04cb5638E3DB8558C': { capacity: 4.8971009e+22, status: 'OK' },
         '0x0a1d951199bBa5420759BF02Cf851F9cb9e0A3b6': { capacity: 3.9167e+22, status: 'OK' },
         '0x0a4cc174dc6678213B0Eb2AD9713e4f5acda81A5': { capacity: 3.155669e+23, status: 'KO' },
         '0x0a8eDC641eDF73887C1E6D13F22fdb6BA5ACeBb8': { capacity: 3.680685e+22, status: 'KO' },
         '0x0b66B71B8f0D8Fd331385c5EB67E8cAbD54b4a60': { capacity: 5.7125219e+22, status: 'OK' },
         '0x101fD3E0aCd802D7821B4a88a7DA96E1D2a85e17': { capacity: 3.341486e+23, status: 'OK' },
         '0x102f1c7129dAeDE2e5f60D8E1B7a6246f0Ca59af': { capacity: 2.7396e+22, status: 'OK' } },
      epoch: 29086,
      success: true }
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $ gawk -F[\':,] -vppp=0x085D3799e83aaD45693ca8F04cb5638E3DB8558C 'BEGIN{PROCINFO["sorted_in"]="@val_num_desc"}/0x/{xx[$2]=$5}END {j=1; for (i in xx){if (i==ppp) {print j,i,xx[i]}j++}}' /tmp/bob.txt 
    6 0x085D3799e83aaD45693ca8F04cb5638E3DB8558C  4.8971009e+22
    Cordialement.

  9. #29
    Membre régulier
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Juillet 2020
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Juillet 2020
    Messages : 175
    Points : 91
    Points
    91
    Par défaut
    Citation Envoyé par N_BaH Voir le message
    oui, c'est largement mieux que la litanie de sed de BeepBeep
    mais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n "s/.*\(0x[^']*\)[^0-9]*\([0123456789\.e+]*\).*/\1:\2/p" fichier
    pourquoi t;d ?
    Merci
    C'est du chinois pour moi
    Existe-t-il une doc permettant de bien décrypté cette commande pour pouvoir la lire en français svp ?
    Car les [ les ( les .* les \1 et \2 m'embrouillent

  10. #30
    Membre régulier
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Juillet 2020
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Juillet 2020
    Messages : 175
    Points : 91
    Points
    91
    Par défaut
    Citation Envoyé par disedorgue Voir le message
    je ne suis pas sure de la sortie voulu, mais peut-être ce sed :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed "s/.*\(0x[^']*\)[^0-9]*\([0123456789\.e+]*\).*/\1:\2/;t;d" fichier
    En gardant les guillemets, sinon ça ne fonctionnera pas car je cherche une quote.
    Ta commande retouchée un peu par N_BaH peut également être raccourcie encore un peu au niveau du 2ème groupe :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n "s/.*\(0x[^']*\)[^0-9]*\([0-9\.e+]*\).*/\1:\2/p"
    J'ai vu également que \d est l'abréviation de la classe de caractères [0-9]
    et que \D est l'abréviation de la classe de caractères [^0-9]
    mais je n'ai pas réussi à les intégrer dans ta commande...

  11. #31
    Membre régulier
    Homme Profil pro
    Chef de projet NTIC
    Inscrit en
    Juillet 2020
    Messages
    175
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Chef de projet NTIC
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Juillet 2020
    Messages : 175
    Points : 91
    Points
    91
    Par défaut
    Voici après avoir travailler ma leçon , la traduction en français de la commande sed suivante:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -n "s/.*\(0x[^']*\)[^0-9]*\([0-9\.e+]*\).*/\1:\2/p" monfichier.txt
    Ligne à nettoyer (monfichier.txt) :
    { candidates:
    { ...
    '0xfeE74c87cEc6e4851b11Ec4B4E7Ff4A54cC982f3': { capacity: 3.834303e+22, status: 'SLASHED' },
    ... },
    epoch: 29086,
    success: true }

    -n : on ne restitue pas le résultat du contenu du fichier avec les modifications, pour afficher seulement les lignes modifiées (p) afin de ne pas prendre en compte les éléments superflus du fichier («*{ candidates:*», «*epoch: 29086,*» et «*success: true }*»

    s : on substitue une ligne du fichier par la sélection des groupes 1 et 2

    [regex] : Définition de la ligne à nettoyer en regex

    .* : N’importe quel nombre de n’importe quel caractère ( ')

    \ : Caractère d’échappement

    ( ) : Définition du 1er groupe de caractères à extraire (0xfeE74c87cEc6e4851b11Ec4B4E7Ff4A54cC982f3)

    0x[^']* : 0x suivit de n’importe quel nombre d’un caractère quelconque sauf « ‘ » (0xfeE74c87cEc6e4851b11Ec4B4E7Ff4A54cC982f3)

    [^0-9]* : N’importe quel nombre d’un caractère quelconque sauf « 0-9 » (': { capacity: )

    ( ) : Définition du 2ème groupe de caractères à extraire (3.834303e+22)

    [0-9\.e+]* : N’importe quel nombre d’un caractère au choix parmi ceux de la classe (3.834303e+22)

    .* : N’importe quel nombre de n’importe quel caractère (, status: 'SLASHED' },)

    \1:\2 : Substituant composé des groupes 1 et 2, séparés par “:”

    p : Affiche les lignes modifiées

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 552
    Points : 19 392
    Points
    19 392
    Par défaut
    je voudrais quand même revenir aux origines du fichier, à la commande qui le génère, pour , si possible (peut-être en modifiant la-dite commande*), donner une solution adaptée.

    --
    * j'ai lu, en cherchant des infos pour corriger ce que je croyais être du JSON, qu'en fait il s'agirait de javascript...
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

+ Répondre à la discussion
Cette discussion est résolue.
Page 2 sur 2 PremièrePremière 12

Discussions similaires

  1. Tri des lignes d'une Table via Formulaire
    Par kato dans le forum Access
    Réponses: 3
    Dernier message: 19/04/2006, 12h53
  2. macro=remove des lignes d un fichier xls et reorga
    Par af_airone dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 26/10/2005, 15h08
  3. Shell pour supprimer des lignes d'un fichier
    Par nelsa dans le forum Autres langages
    Réponses: 2
    Dernier message: 20/09/2004, 12h26
  4. Extraire des lignes d'un fichier en commande bash
    Par newnew dans le forum Linux
    Réponses: 3
    Dernier message: 27/07/2004, 16h22
  5. Réponses: 4
    Dernier message: 24/04/2003, 22h28

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