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 :

Extraire chaine depuis fichier


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Septembre 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2016
    Messages : 2
    Par défaut Extraire chaine depuis fichier
    Bonjour,

    je cherche à faire un script shell qui pourrait me filtrer un fichier de log, je m'explique, j'ai ce fichier :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    (idf=AL69,part=ETEBAIX,fname=/apps/cftant/recparis/) Number of error(s) 0 Ending Session on 07/09/2016 Time is 03:53:20
    (part=M086204D,idf=ADCVIS01,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 06/09/2016 Time is 21:02:11
    (idf='000000P9',part=BNP9IC01,fname=/apps/cftant/re) Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:39:41
    (idf='000000P9',part=BNP9IC02,fname=/apps/cftant/re) Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:40:08
    (idf='000000P9',part=BNP9IC03,fname=/apps/cftant/re) Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:40:34
    (part=IA179040,idf=OXALYSB3,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    (part=IA105002,idf=OXALYSB1,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    (part=IA179020,idf=OXALYSB2,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    (part=IA179040,idf=OXALYSB3,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:40:17
    (part=IA179040,idf=OXALYSB3,fname=/apps/cftant/recp) Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:26:57

    je dois récupérer l'idf entre les parenthèses et garder le reste de la ligne, cela donnerait :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    AL69 Number of error(s) 0 Ending Session on 07/09/2016 Time is 03:53:20
    ADCVIS01 Number of error(s) 0 Ending Session on 06/09/2016 Time is 21:02:11
    000000P9 Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:39:41
    000000P9 Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:40:08
    000000P9 Number of error(s) 0 Ending Session on 06/09/2016 Time is 22:40:34
    OXALYSB3 Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    OXALYSB1 Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    OXALYSB2 Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:50:13
    OXALYSB3 Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:40:17
    OXALYSB3 Number of error(s) 0 Ending Session on 07/09/2016 Time is 14:26:57
    Par avance, merci

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 136
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 136
    Par défaut
    Donc, en gros :
    • Supprimer ce qui est à gauche de idf=
    • Garder la chaine qui suit jusqu'à la première virgule
    • Supprimer depuis cette virgule jusqu'à la parenthèse fermante
    • Garder le reste de la ligne


    Quelque chose comme :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed 's/.*idf=\([^,]*\)[^)]*\(.*$\)/\1\2/'
    A tester parce que je n'ai pas sous la main les moyens de le faire.
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

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

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

    Informations forums :
    Inscription : Novembre 2010
    Messages : 3 041
    Par défaut
    salut,

    @al1_24, c'était pas loin je reprends ton idée et propose (testé) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -r "s/.+idf='?([^,']*).+(Number of error.+)/\1 \2/"

  4. #4
    Candidat au Club
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Septembre 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Seine Saint Denis (Île de France)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Septembre 2016
    Messages : 2
    Par défaut
    Merci, c'est exactement ce dont j'avais besoin

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

Discussions similaires

  1. [XL-2010] Extraire icone depuis fichier insérer en tant qu'objet sur une feuille
    Par jdizier dans le forum Macros et VBA Excel
    Réponses: 0
    Dernier message: 21/01/2016, 17h54
  2. [Batch] extraction chaines depuis fichier
    Par Alderick dans le forum Scripts/Batch
    Réponses: 5
    Dernier message: 01/07/2015, 12h41
  3. extraire données depuis fichier xml
    Par seeif dans le forum Format d'échange (XML, JSON...)
    Réponses: 6
    Dernier message: 10/07/2009, 10h18
  4. Extraire chaine d'un fichier texte
    Par eknd dans le forum Langage
    Réponses: 3
    Dernier message: 04/10/2007, 16h35
  5. Extraction de données depuis fichier .NDX ...
    Par Olif_C dans le forum WinDev
    Réponses: 4
    Dernier message: 30/08/2005, 11h57

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