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 :

sed : pour filtrer (sélectioner) certaines lignes d'un fichier


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut sed : pour filtrer (sélectioner) certaines lignes d'un fichier
    Bonjour,
    Prenons un exemple simple pour comprendre.
    Listons le contenu du fichier f01.csv :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Liam@HAL42:~/projets/Test_cmd_shell_21$ cat f01.csv 
    a;1;aline;0;aze
    b;22;berthe;0;rtyui
    c;333;charlotte;f;op
    d;4444;diane;0;q
    Dans le troisième champ se trouve un drapeau ou flag.
    Comment sélectionner les lignes dont le drapeau est positionné à : 'f' ?
    avec sed ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Liam@HAL42:~/projets/Test_cmd_shell_21$ cat f01.csv | sed "-quelles options ici pour que ..." 
    c;333;charlotte;f;op

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

    Informations forums :
    Inscription : Février 2008
    Messages : 7 664
    Par défaut
    Bonjour,

    pourquoi sed ?

    un CSV, ça se traite plus facilement avec awk :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk -F ';' '$3=="f"' tonFichier.csv
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Expert confirmé Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 293
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 293
    Par défaut
    Bonjour

    Pourquoi awk ou sed puisqu'il ne s'agit que d'un filtre ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $ grep '^[^;]*;[^;]*;[^;]*;f;' fichier.txt
    c;333;charlotte;f;op

  4. #4
    Expert confirmé
    Avatar de becket
    Profil pro
    Informaticien multitâches
    Inscrit en
    Février 2005
    Messages
    2 854
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations professionnelles :
    Activité : Informaticien multitâches
    Secteur : Service public

    Informations forums :
    Inscription : Février 2005
    Messages : 2 854
    Par défaut
    Citation Envoyé par Flodelarab Voir le message
    Bonjour

    Pourquoi awk ou sed puisqu'il ne s'agit que d'un filtre ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $ grep '^[^;]*;[^;]*;[^;]*;f;' fichier.txt
    c;333;charlotte;f;op
    Je lui préfère un

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     grep -E '^([^;]*;){3}f;' fichier.txt

  5. #5
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut Re
    Merci becket
    J'arrive à comprendre en lisant l'expression régulière, me reste à apprendre à les écrire.
    Celle ci est plus compacte que ce que j'imaginais.

  6. #6
    Expert confirmé
    Homme Profil pro
    Développeur informatique en retraite
    Inscrit en
    Avril 2008
    Messages
    2 103
    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 103
    Par défaut
    Pour info, il existe des outils pour générer, tester ou expliquer des expressions régulières.

  7. #7
    Expert confirmé Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 358
    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 358
    Par défaut
    Citation Envoyé par Liamm Voir le message
    Merci becket
    J'arrive à comprendre en lisant l'expression régulière, me reste à apprendre à les écrire.
    Celle ci est plus compacte que ce que j'imaginais.
    Pour t'aider à ça, juste une question: comment lis-tu la solution de Becket et celle de Flodelarab ?

    ainsi que celle-ci: ';f;[^;]*$' .

    Si tu sais les transformer en une phrase claire, et une seule, tu devrais par la suite savoir passer de la phrase à la syntaxe elle-même.

  8. #8
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut Merci
    Merci N_BaH,

    Effectivement avec awk ou gawk l'écriture est compacte et c'est très rapide.
    Désormais je ferai comme cela.
    Merci.
    Par curiosité pouvait-on le faire avec la commande sed ?

    NB: Je traite souvent des fichiers en batch; aussi je sépare les champs par le caractère ";".
    Les commandes que j'utilise le plus sont : cat, sed, cut, gawk, sort, et join.

  9. #9
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut Merci
    Merci Flodelarab,

    Effectivement je n'avais pas pensé à la commande grep.
    Merci.

    NB: En fait je sais que grep existe, mais je ne suis pas familiarisé avec elle (grep).

  10. #10
    Expert confirmé Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 293
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 293
    Par défaut
    grep, c'est juste pour agrandir ton champ des possibles. Le but du message était de montrer une expression rationnelle qui marche avec grep, sed, awk.

  11. #11
    Membre confirmé Avatar de Liamm
    Femme Profil pro
    Enseignant
    Inscrit en
    Janvier 2019
    Messages
    164
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant

    Informations forums :
    Inscription : Janvier 2019
    Messages : 164
    Par défaut Re
    grep, c'est juste pour agrandir ton champ des possibles. Le but du message était de montrer une expression rationnelle qui marche avec grep, sed, awk.
    Bien compris; c'est plus avec les expressions régulières (ou rationnelles) que j'ai du mal.

    NB: Pour info, la place de mon champ "drapeau" ou "flag" se trouve en fait en 21ème position dans mon vrai fichier. Ça va donc faire une expression à rallonge !

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

Discussions similaires

  1. Utiliser sed pour réécrire certaines lignes d'un fichier ?
    Par Ezzmazz dans le forum Shell et commandes GNU
    Réponses: 10
    Dernier message: 02/11/2019, 13h45
  2. [PowerShell] Comment récupérer certaines lignes d'un fichier pour ensuite s'en servir
    Par Zipper963 dans le forum Scripts/Batch
    Réponses: 5
    Dernier message: 13/12/2012, 15h35
  3. [XL-2007] Une macro pour copier seulement certaines lignes d'un fichier à un autre
    Par asgard78 dans le forum Macros et VBA Excel
    Réponses: 5
    Dernier message: 05/10/2010, 14h10
  4. Réponses: 2
    Dernier message: 19/09/2006, 15h04
  5. Supprimer certaines lignes d'un fichier texte
    Par kek_net dans le forum Langage
    Réponses: 2
    Dernier message: 10/04/2006, 11h21

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