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 :

Extraction d'une chaîne de caractère


Sujet :

Shell et commandes GNU

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2014
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2014
    Messages : 135
    Par défaut Extraction d'une chaîne de caractère
    Bonjour,

    Je bloque sur une petite extraction d'une sous chaîne de caractère que voici :
    /XXX/AAA.html-<td align="center">&nbsp;<br>ty32101.google.fr</td>

    /XXX/AAA.html-<td align="center">pz32891.google.fr<br>&nbsp;</td>
    /XXX/AAA.html-<td align="center">&nbsp;<br>av67384.google.fr</td>

    /XXX/AAA.html-<td align="center">&nbsp;<br>fp87432.google.fr</td>
    Mon objectif est de récupérer la partie avant "google.fr" (fp87432).
    Ma difficulté est que la forme n'est pas constante...

    J'étais parti vers la commande awk avec en filtrant sur le .google.fr comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    awk -F '.google.fr' '{print $1}' test.txt
    Voici ce que j'obtiens :
    /XXX/AAA.html-<td align="center">&nbsp;<br>ty32101

    /XXX/AAA.html-<td align="center">pz32891
    /XXX/AAA.html-<td align="center">&nbsp;<br>av67384

    /XXX/AAA.html-<td align="center">&nbsp;<br>fp87432
    J'aimerais effectuer un cut sur les 7 derniers caractères, mais je bloque à cette étape

    Avez-vous une solution à cela ?

    Merci par avance,

  2. #2
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 134
    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 134
    Par défaut
    Il y a toujours 7 caractères ?
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    sed -E 's/^.*(.{7})\.google\.fr.*$/\1/' test.txt
    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
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Décembre 2014
    Messages
    135
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 31
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2014
    Messages : 135
    Par défaut
    Effectivement, il y aura toujours 7 caractères.

    Merci pour votre réactivité !

    Cependant, pouvez-vous m'expliquer la commande que je puisse en débrouiller tout seul la prochaine fois ?

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

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

    Et pourquoi pas un filtre grep avec une regex perl et un lookbehind pour le chevron fermant et un lookahead pour le "google.fr" ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $ cat afac_csur.txt
    /XXX/AAA.html-<td align="center">&nbsp;<br>ty32101.google.fr</td>
     
    /XXX/AAA.html-<td align="center">pz32891.google.fr<br>&nbsp;</td>
    /XXX/AAA.html-<td align="center">&nbsp;<br>av67384.google.fr</td>
     
    /XXX/AAA.html-<td align="center">&nbsp;<br>fp87432.google.fr</td>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    $ grep -Po "(?<=>)[^>]*(?=\.google\.fr)" afac_csur.txt
    ty32101
    pz32891
    av67384
    fp87432

  5. #5
    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
    avec awk

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     awk ' { print gensub(".*>([^.]*).*<...>","\\1","1" )  }' fichier.txt

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

Discussions similaires

  1. Jointure impliquant l'extraction d'une chaîne de caractères
    Par rplog dans le forum Requêtes et SQL.
    Réponses: 2
    Dernier message: 21/06/2011, 15h41
  2. extraction d'une chaîne de caractère
    Par mackla dans le forum C
    Réponses: 14
    Dernier message: 14/04/2008, 09h13
  3. [BO 5.1] Extraction dans une chaîne de caractères
    Par ruton dans le forum Débuter
    Réponses: 2
    Dernier message: 22/03/2008, 15h06
  4. Extraction d'une chaîne de caractère
    Par Hathor dans le forum VBScript
    Réponses: 1
    Dernier message: 25/04/2007, 07h36
  5. Extraction d'une chaîne de caractère avec SQL
    Par opeo dans le forum MS SQL Server
    Réponses: 13
    Dernier message: 28/07/2006, 15h36

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