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

Python Discussion :

Expression Régulière Syntaxe [Python 3.X]


Sujet :

Python

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 57
    Points : 62
    Points
    62
    Par défaut Expression Régulière Syntaxe
    j'essaye de contrôler des variables ( contrôle d'extension de fichier ) à l'aide d'expressions régulières et de re.match ou re.fullmatch
    je dois filtrer les donnés qui contient des . et * pour ne garder que celle qui commence par *. ou . avec l'expression r'(^(\x2E){1}(.)+|^(\x2A\x2E){1}(.)+)'
    ça marche à l'exception du cas ou la variable ne contient que des . ('.' seule sortant en erreur alors que '..' '....' sort correct au lieu de sortir aussi en erreur )
    l'un de vous aurait-il une idée d'où vient mon erreur ?

    Et visiblement il y doit avoir une erreur car la fonction Re.sub ne donne pas de bon resultat

    re.sub(r'(^(\x2E){1}(.)+|^(\x2A\x2E){1}(.)+)','fin','*.test')

    'fin'

  2. #2
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Si vous voulez attraper les chaînes de caractères commençant par '.' mais ne contenant pas '.' dans les caractères suivants, c'est un peu barbare comme écriture mais çà donne: r'^\.[^\.]+$'.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 57
    Points : 62
    Points
    62
    Par défaut
    c'est dans l'idée

    si la chaine commence par *.toto ou par .toto c'est ok et la suite du traitement les élimines mais pour les chaines ..toto ou .. la suite du traitement renvoie dégage en exception considérant une erreur de saisi
    merci pour ton aide je viens de tester et ça marche .. bon je ne sais pas pourquoi le nombre de caractère n’était pas pris en compte dans mon expression mais la tienne me convient

    par contre le re.sub lui ne marche pas correctement

    re.sub(r'^\.[^\.]+$','vrai|','.test')

    retourne 'vrai|' au lieu de 'vrai|test'

  4. #4
    Expert éminent sénior
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 283
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 283
    Points : 36 770
    Points
    36 770
    Par défaut
    Citation Envoyé par moons17 Voir le message
    par contre le re.sub lui ne marche pas correctement
    re.sub(r'^\.[^\.]+$','vrai|','.test') remplace ce qui matche par 'vrai|'.
    Si on veut retrouver "ce qui matche" dans la chaîne de sortie, il faut grouper et indexer: re.sub(r'(^\.[^\.]+)$',r'vrai|\1','.test').

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  5. #5
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2010
    Messages
    57
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2010
    Messages : 57
    Points : 62
    Points
    62
    Par défaut
    comportement bizarre

    re.sub('\.','levrai','.poto')
    'levraipoto'
    >>> re.sub(r'\.','levrai','.poto')
    'levraipoto'
    >>> re.sub(r'^\.','levrai','.poto')
    'levraipoto'
    >>> re.sub(r'^\.[^\.]','levrai','.poto')
    'levraioto'
    >>> re.sub(r'^\.[^\.]+','levrai','.poto')
    'levrai'

    je crois avoir saisi mon erreur d'analyse ,Essayer de supprimer avec la chaine de match n 'est pas la bonne solution . faut que je regarde avec les groupes ou autres

  6. #6
    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,

    sur le même principe, avec une syntaxe un peu différente :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    >>> re.sub(r'^\*?\.(?=[^.]+$)', 'vrai|', '.test')
    'vrai|test'
    >>> re.sub(r'^\*?\.(?=[^.]+$)', 'vrai|', '*.test')
    'vrai|test'
    >>> re.sub(r'^\*?\.(?=[^.]+$)', 'vrai|', '..test')
    '..test'
    >>> re.sub(r'^\*?\.(?=[^.]+$)', 'vrai|', '*..test')
    '*..test'
    >>> re.sub(r'^\*?\.(?=[^.]+$)', 'vrai|', '*.te...st')
    '*.te...st'
    ici on utilise un lookahead (la parenthèse (?=...)) qui n'est de fait pas comptabilisé dans la substitution
    la regexp match donc 1 * éventuel suivi d'exactement 1 point en début de chaine, le(s)quel caractère(s) sont|est suivi(s) d'1 ou plusieurs caractère dont aucun n'est un point et ce jusqu'à la fin, ce qui est substitué c'est tout ce qui n'entre pas dans le lookahead, donc le premier ou les deux premiers caractère(s).

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

Discussions similaires

  1. Réponses: 0
    Dernier message: 04/01/2016, 17h56
  2. expression régulière syntaxe
    Par Oluha dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 05/06/2007, 13h47
  3. [RegEx] Pb de syntaxe d'expression régulière
    Par renaudjuif dans le forum Langage
    Réponses: 5
    Dernier message: 07/09/2006, 20h52
  4. [RegEx] preg_replace et syntaxe des expressions régulières
    Par MmoulinexX dans le forum Langage
    Réponses: 4
    Dernier message: 04/06/2006, 23h57

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