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

Java Discussion :

Expression régulière en java


Sujet :

Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2014
    Messages : 2
    Par défaut Expression régulière en java
    bonjour à tous ;

    please help, en effet j'aimerai pourvoir recupérer toutes les valeurs possible d'une expression regulière en java.
    exple : bo[iî]te(s)?
    boite
    boites
    boîte
    boîtes

    Est-ce possible en général ? si oui y'a t'il des fonction pré-définis pour cela ou alors il faut parcourir l'expression regulière caractère par caractère ?

    merci d'avance.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Billets dans le blog
    2
    Par défaut
    Salut,

    Les expressions régulières existent en effet en java : on utilise la classe Pattern pour s'en servir (et accessoirement de la classe Matcher). Mais il faut les définir les expressions. Là, ce que tu demandes, ça m'a l'air d'être un peu différent, c'est de trouver tous les mots qui se ressemblent de point de vue de "règles syntaxiques" : si tu dois définir toutes les expressions régulières pour tous les mots de la langue française, voire de plusieurs langues, tu vas avoir du boulot pour un bout de temps. Il y a d'autres types d'algorithmes pour gérer ce genre de chose (Distances de Levenstein, soundex...) voire des API, tout dépend de ce que tu cherches à faire au final.
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

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

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Oui c'est possible mais je ne connais pas de solution toute faite. Et pour cause : tu utilises le principe de l'expression régulière à l'envers.
    Tout d'abord, tu dois faire la liste exhaustive des expressions régulières supportées.
    Par exemple, le pattern "*" (étoile) ne pourra jamais être traité.
    Ensuite, tu pourras par exemple construire une liste chaînée contenant des cases. Chaque case contient toutes les possibilités d'une sous-partie de l'expression régulière.
    Dans ton exemple :
    case 1 : contient une sous-case "bo"
    case 2 : contient 2 sous-cases "i" et "î"
    case 3 : contient 1 sous-case "te"
    case 4 : contient 2 sous-cases "s" et "vide"

    Pour le parcours, tu utilises le principe du compteur kilométrique de voiture. Tu construis ta chaîne en changeant toujours la sous-case de la case 4. Lorsque tu revient à la première sous-case de la case 4, tu changes la sous-case de la case 3 et tu remontes de manière récursive jusqu'à la première case.
    Quand tu reviens à la sous-case 1 d'une case, tu incrémentes la sous-case à lire de la case précédente.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  4. #4
    Modérateur

    Profil pro
    Inscrit en
    Septembre 2004
    Messages
    12 582
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2004
    Messages : 12 582
    Par défaut
    Et bien entendu ce n'est pas possible pour les expressions régulières qui acceptent une infinité de valeurs.
    Exemple : je suis musi+c.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  5. #5
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2014
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Mai 2014
    Messages : 2
    Par défaut
    Merci à tous,

    dinobogan j'ai suivis ton idée et j'obtiens bien ce je voulais
    thelvin évidemment les cas infinis ne peuvent être traités

  6. #6
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Citation Envoyé par tampico Voir le message
    thelvin évidemment les cas infinis ne peuvent être traités
    Le truc c'est que ça représente la majorité des cas d'utilisation regexp

  7. #7
    Membre Expert Avatar de Uther
    Homme Profil pro
    Tourneur Fraiseur
    Inscrit en
    Avril 2002
    Messages
    4 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Pyrénées Orientales (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Tourneur Fraiseur

    Informations forums :
    Inscription : Avril 2002
    Messages : 4 690
    Par défaut
    Et on peut aussi assez facilement arriver a des quantité de résultat astronomique et donc intraitables même avec des cardinalité finies. Un simple [A-Z]{6} retournerait plus de 3 Go de résultats.

Discussions similaires

  1. Les expressions régulières en java
    Par blackhock dans le forum Général Java
    Réponses: 2
    Dernier message: 21/04/2009, 13h05
  2. Expression régulière avec java
    Par mouvma dans le forum Général Java
    Réponses: 2
    Dernier message: 18/01/2008, 17h00
  3. expression régulière en java
    Par shirya dans le forum Collection et Stream
    Réponses: 4
    Dernier message: 21/09/2007, 16h10
  4. expression régulière en java
    Par Karine2007 dans le forum Langage
    Réponses: 9
    Dernier message: 07/07/2007, 12h35
  5. Expressions régulières en Java
    Par jason69 dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 04/07/2007, 10h50

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