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 :

regex sur groupe répétitif


Sujet :

Shell et commandes GNU

  1. #1
    Membre à l'essai
    Homme Profil pro
    Chef de projet sur HPC
    Inscrit en
    Août 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet sur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 27
    Points : 19
    Points
    19
    Par défaut regex sur groupe répétitif
    Bonjour,

    Encore besoin d'aide sur une regex un peu complexe...je cherche à faire une regex pour sélectionner ce type de ligne.

    HEXA N/A 0 N/A N/A 2 N/A 0 0 0
    PENTA N/A 0 N/A N/A 0 N/A 0 0 0
    QUAD4 3 874 3 117 52 N/A N/A N/A N/A
    TETRA N/A 0 N/A N/A N/A N/A 0 0 0
    TRIA3 15 N/A N/A 0 N/A N/A N/A N/A N/A

    J'arrive à sélectioner le début : \s\s\s\w{5}.*(N/A|\d)

    Mais je récupère aussi ces lignes :

    TRIA3 97715 7.46 ++++ 90.01
    TRIA3 137464 7.85 ++++ 106.10
    TRIA3 142801 9.23 ++++ 93.18

    J'ai tenté \s\s\s\w{5}.*(N/A|\d){9} mais ça ne fonctionne pas. En fait, je voudrais vérifier 9 fois le bloc (espace et N/A ou 0-9).

    Une idée ?

    Merci.

  2. #2
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 278
    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 278
    Points : 12 726
    Points
    12 726
    Par défaut
    Bonjour,

    Pas compris grand chose, pourquoi tu ne vires pas carrément les lignes avec la série de '+++++' ?
    Avec quel commande tu fais ta regex (sed,grep,perl,python,awk,expr,....) ????
    Cordialement.

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 458
    Points
    13 458
    Par défaut
    Bonjour,

    SuperJoker, es-tu sûr d'avoir échappé au bon endroit?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $ sed 's@\( N/A\| [0-9]\+\)\{9\}@bozo@' <<<"N/A 235 N/A N/A 458 487 220 N/A N/A N/A" 
    N/Abozo
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  4. #4
    Membre à l'essai
    Homme Profil pro
    Chef de projet sur HPC
    Inscrit en
    Août 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet sur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 27
    Points : 19
    Points
    19
    Par défaut
    Bonjour et merci pour vos retours,

    En fait, je lis un fichier en entrée et je ne traite que certaines lignes (celles mentionnées). Mais avec ma regex, je sélectionne aussi d'autres lignes (que je ne veux pas !) car ma regex est incomplète

    Je veux donc sélectionner :
    HEXA N/A 0 N/A N/A 2 N/A 0 0 0
    PENTA N/A 0 N/A N/A 0 N/A 0 0 0
    QUAD4 3 874 3 117 52 N/A N/A N/A N/A

    Mais pas :
    QUAD4 202651 57.28 53.21 155.58 ++++ 0.00 0.60 ++++
    QUAD4 202665 64.11 54.59 150.56 ++++ 0.00 0.58 ++++
    QUAD4 212185 58.89 40.02 151.68 ++++ 0.04 0.54 ++++
    QUAD4 213169 56.39 51.84 155.79 ++++ 0.00 0.62 ++++

    Je vrais creuser la solution de Flodelarab.

    @+

  5. #5
    Invité
    Invité(e)
    Par défaut
    Peux-tu donner un fichier de test?

  6. #6
    Membre à l'essai
    Homme Profil pro
    Chef de projet sur HPC
    Inscrit en
    Août 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet sur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 27
    Points : 19
    Points
    19
    Par défaut
    Salut,

    Désolé mais étant en plein développement, je vois ton message que cet après midi

    Le fichier fais plusieurs millier de lignes donc ça va être difficile, j'ai juste mis 2 passages de fichiers comme exemple à sélecctionner et exclure.

    HEXA N/A 0 N/A N/A 2 N/A 0 0 0
    PENTA N/A 0 N/A N/A 0 N/A 0 0 0
    QUAD4 3 874 3 117 52 N/A N/A N/A N/A
    QUAD4 202651 57.28 53.21 155.58 ++++ 0.00 0.60 ++++
    QUAD4 202665 64.11 54.59 150.56 ++++ 0.00 0.58 ++++
    QUAD4 212185 58.89 40.02 151.68 ++++ 0.04 0.54 ++++
    QUAD4 213169 56.39 51.84 155.79 ++++ 0.00 0.62 ++++

    En fait, je sais sélectionner chaque groupe mais je ne sais pas comment ajouter la condition ET sur ces groupes.

    Je veux sélectionner les lignes commençant pas 5 alpha (\s\s\s\w{5}) et qui comportant à la suite 9 colonnes égales à N/A ou un numérique ((N/A|\d){9} => C'est bon ça).

    Voili, voilà.

  7. #7
    Expert éminent sénior Avatar de disedorgue
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    Décembre 2012
    Messages
    4 278
    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 278
    Points : 12 726
    Points
    12 726
    Par défaut
    Je réitère ma question, ta regex tu la veux pour quelle commande ?
    \s => pour space (espace en posix donne [:space:])
    \w pour word (mot en posix peut-être [:word:] si la classe est définie)
    Donc je ne comprend ce que tu veux dire par 5 alpha...

    (N/A|\d){9} => c'est bon en perl ou en gnu sed avec l'option -r
    Cordialement.

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

    Informations forums :
    Inscription : Septembre 2005
    Messages : 5 243
    Points : 13 458
    Points
    13 458
    Par défaut
    J'enfonce le clou de Disedorgue: 5 alphas pour le mot HEXA n'est-il pas prétentieux?
    Cette réponse vous apporte quelque chose ? Cliquez sur en bas à droite du message.

  9. #9
    Membre à l'essai
    Homme Profil pro
    Chef de projet sur HPC
    Inscrit en
    Août 2003
    Messages
    27
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Chef de projet sur HPC
    Secteur : Industrie

    Informations forums :
    Inscription : Août 2003
    Messages : 27
    Points : 19
    Points
    19
    Par défaut
    Hello,

    Désolé mais parti sur d'autres projets puis congés donc de retour sur ce sujet

    En effet, la tête dans le guidon je n'avais pas vu que tous les items de la 1er colonnes n'avaient pas la même longueur, enfin ça fait 5 de long de type alpha-numérique-espace

    J'avance : \s\s\s[\w]{1,5} me permet de sélectionner la 1er colonne mais je butte sur les 9 colonnes égales à N/A ou nombre...

    Pour le moment je teste avec http://www.regexr.com/

    Merci.

    Voilà où j'en suis avec : \s\s\s[\w]{1,5}[\s+(N/A|\d+)]{9} mais les 2 premières lignes ne devraient pas être sélectionnées ! je ne suis pas loin mais il manque un truc...

    84168848 15:23:33 XREAD 37 READ 4655.438 15:24:47 SEMFREQ 770 EXIT
    OPTION BLOCKS BLOCKS BLOCKS OPTION HIWATER SUB_DMAP DMAP OPN/CLS
    QUAD4 0 404 0 2 17 N/A N/A N/A N/A
    TETPR N/A 0 N/A N/A N/A N/A 0 0 0
    TETRA N/A 0 N/A N/A N/A N/A 0 0 0
    TRIA3 1 N/A N/A 0 N/A N/A N/A N/A N/A
    BAR N/A N/A N/A N/A N/A 0 N/A N/A N/A
    BEAM N/A N/A N/A N/A N/A 0 N/A N/A N/A
    HEXA N/A 113 N/A N/A 8 N/A 0 0 0
    PENTA N/A 0 N/A N/A 0 N/A 0 0 0
    QUAD4 0 1515 0 88 102 N/A N/A N/A N/A
    TETPR N/A 0 N/A N/A N/A N/A 0 0 0
    TETRA N/A 0 N/A N/A N/A N/A 0 0 0
    TRIA3 2 N/A N/A 0 N/A N/A N/A N/A N/A

    Edit, ayé ça marche

    \s{3}[\w]{1,5}(\s+N/A|\s+\d+){9}

    Y'a sûrement mieux mais pas le temps de creuser

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

Discussions similaires

  1. [MySQL 4.0] Question sur GROUP BY
    Par Fabouney dans le forum Langage SQL
    Réponses: 10
    Dernier message: 25/09/2006, 19h45
  2. [Access 2000] Evénement click sur groupe d'option
    Par Mariboo dans le forum Access
    Réponses: 1
    Dernier message: 22/09/2006, 14h52
  3. Regex sur adresse IP
    Par lobiman dans le forum Langage
    Réponses: 5
    Dernier message: 12/09/2006, 16h46
  4. [C.R .8.5] doublons de référence sur groupes différents
    Par leuke dans le forum SAP Crystal Reports
    Réponses: 24
    Dernier message: 14/11/2005, 11h15
  5. ordre correct sur group ?
    Par Force59 dans le forum Langage SQL
    Réponses: 9
    Dernier message: 02/04/2004, 09h27

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