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 :

Pattern matching avec awk (ou sed)


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mars 2012
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2012
    Messages : 30
    Points : 18
    Points
    18
    Par défaut Pattern matching avec awk (ou sed)
    Bonjour,

    j'ai un fichier file.txt contenant :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
      Test1:
         Type: Number
         Description: ceci est le test1
         Default: '123'
      Test2:
         Type: String
         Description: ceci est le test2
         Default: '456'
    Je cherche une commande me permettant de récupérer la valeur des champs du bloc sous le pattern recherché afin de les afficher dans 1 seule ligne et la sauvegarder dans un autre fichier de type CSV.

    exemple pour le mot clé Test1:
    => résultat retourné attendu = Number,ceci est le test1,123
    Comment je vois les choses: la commande récupère la 1ere ligne commençant par Type: ou Description: ou Default sous le pattern recherché Test1:

    Si je pouvais choisir quelle valeur je souhaite sauvegarder ce serait parfait:
    par exemple uniquement les valeurs Type et défaut (sans la Description).
    Ce qui donnerait toujours pour Test1: Number,123

    Merci pour votre aide !

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

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

    les étiquettes ont toutes toujours le même nom, ont un format fixe (: le nom des test commence à la colonne 3 (après 2 espaces), et les étiquettes commencent à la colonne 6 (après 5 espaces)), et sont dans un ordre immuable ?

    et évidemment, le format émane d'une commande qui n'a pas la possibilité d'afficher les données dans un format plus pratique ?!
    .
    N'oubliez pas de consulter les cours shell, la FAQ, et les pages man.

  3. #3
    Membre confirmé
    Profil pro
    Inscrit en
    Août 2010
    Messages
    345
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2010
    Messages : 345
    Points : 539
    Points
    539
    Par défaut
    Salut,
    Ou est ce que tu bloques ?
    Perso, je ne vois aucun point de blocage !
    Cordialement.

  4. #4
    Expert éminent sénior Avatar de Flodelarab
    Homme Profil pro
    Inscrit en
    Septembre 2005
    Messages
    5 242
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Charente (Poitou Charente)

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 242
    Points : 13 457
    Points
    13 457
    Par défaut
    Bonjour

    Une fois que tu auras ton fichier csv, tu feras tous les filtres que tu veux facilement avec awk.

    À ta place, j'utiliserais sans doute tac avant de traiter le fichier, pour que la première ligne de chaque bloc devienne le signal qu'il faut vider la mémoire dans la sortie.
    Sinon awk semble un bon outil pour le traitement proprement dit, avec le ":" pour séparateur.
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  5. #5
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    Novembre 2010
    Messages
    3 035
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 035
    Points : 8 400
    Points
    8 400
    Par défaut
    salut,

    une façon de faire, parmi d'autres :
    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
    $0 ~ "^[ \t]*" PATTERN ":[ \t]*$" {
       z = 4
       next
    }
     
    z && /(Type|Description|Default):/ {
       z--
       FS = ":[ \t\x27]*"
       s = s $2 ","
    }
     
    z == 1 {
       z--
       print substr(s, 0, length(s)-2)
    }
    ou en oneliner :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk -vPATTERN="Test1" '$0 ~ "^[ \t]*"PATTERN":[ \t]*$" {z=4;next} z && /(Type|Description|Default):/ {z--;FS=":[ \t\x27]*";s=s$2","} z==1 {z--;print substr(s,0,length(s)-2)}' fichier
    et le résultat :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $ awk -vPATTERN="Test1" -f script fichier
    Number,ceci est le test1,123
    $ awk -vPATTERN="Test2" -f script fichier
    String,ceci est le test2,456
    $ awk -vPATTERN="coincoin" -f script fichier
    $ awk -vPATTERN="Test" -f script fichier
    $ awk -vPATTERN="Test1:" -f script fichier

  6. #6
    Membre à l'essai
    Homme Profil pro
    Inscrit en
    Mars 2012
    Messages
    30
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Mars 2012
    Messages : 30
    Points : 18
    Points
    18
    Par défaut
    Oui les étiquettes ont le même nom est le format est fixe.

    Merci à tous et particulièrement à BufferBob, c'est exactement la réponse que j'attendais !!

    PS: déosolé pour le retard de ma réponse, j'étais en vacances

Discussions similaires

  1. pattern matching avec boost graph
    Par makrouna dans le forum Boost
    Réponses: 2
    Dernier message: 30/07/2011, 00h56
  2. Réponses: 1
    Dernier message: 05/06/2009, 10h48
  3. Suppression de caracteres en fin de ligne avec awk ou sed
    Par julinho99 dans le forum Shell et commandes GNU
    Réponses: 5
    Dernier message: 04/11/2008, 18h03
  4. [débutant] Pattern matching avec un n-uplet
    Par coyotte507 dans le forum Caml
    Réponses: 8
    Dernier message: 29/09/2008, 07h51
  5. decoupage avec awk + sed
    Par killapig dans le forum Shell et commandes GNU
    Réponses: 8
    Dernier message: 12/04/2007, 10h40

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