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

C Discussion :

Expressions régulières


Sujet :

C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    119
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2004
    Messages : 119
    Par défaut Expressions régulières
    Bonjour, je développe une appli qui doit à un moment donné faire une recherche à partir d'un nom, et pour cela j'utilise une expression régulière, en me basant sur le tuto http://nicolasj.developpez.com/articles/regex/

    J'ai donc le code ci-dessous :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    char *msgReponseTmp = "";
    int err;
    regex_t preg;
    char str_regex[strlen(motRecherche)+8];
    sprintf(str_regex, "(.)*%s(.)*", motRecherche);
    err = regcomp (&preg, str_regex, REG_NOSUB | REG_ICASE);
    if (err == 0)
    {
    	int match = regexec (&preg, mot, 0, NULL, 0);
    	regfree (&preg);
    	if(match == 0)
    	{
    		char *msgReponseTmp2;
    		sprintf(msgReponseTmp2, "%s%s\t%d\n", msgReponseTmp, fic->nom, fic->taille);
    		msgReponseTmp = msgReponseTmp2;
    	}
    }
    L'idée c'est que je reçois un mot (qui se trouve dans la variable "mot"), je la compare avec la valeur contenue dans la variable motRecherche que je place dans une expression régulière de type (.)*mot(.)*, mais ça ne matche jamais !!

    Je pense que d'une part mon expression régulière est peut-être foireuse, et d'autre part j'ai peut-être mal choisi les options dans regcomp (REG_NOSUB et REG_ICASE) ?

    Ce que je veux faire, c'est vérifier si "mot" est présent dans "motRecherche", et si possible en tenant compte des accents et des majuscules.
    Par exemple, si motRecherche = developpez.net et mot = Développez, je voudrais que ça matche...

    Je ne pense pas que ça soit compliqué une fois qu'on a compris les expressions régulières, mais j'en suis pas encore là...

  2. #2
    Membre chevronné Avatar de corentin59
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    462
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 462
    Par défaut
    Citation Envoyé par zarbiman Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    char str_regex[strlen(motRecherche)+8];
    Je ne suis pas persuadé que cette ligne marche. Envisage plutôt un malloc (et un free). D'autre part, je pense qu'il vaut mieux un +9, pour le '\0' final.

  3. #3
    Expert confirmé
    Avatar de Thierry Chappuis
    Homme Profil pro
    Enseignant Chercheur
    Inscrit en
    Mai 2005
    Messages
    3 499
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 48
    Localisation : Suisse

    Informations professionnelles :
    Activité : Enseignant Chercheur
    Secteur : Industrie Pharmaceutique

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 499
    Par défaut
    Citation Envoyé par corentin59 Voir le message
    Je ne suis pas persuadé que cette ligne marche. Envisage plutôt un malloc (et un free). D'autre part, je pense qu'il vaut mieux un +9, pour le '\0' final.
    Ca fonctionne en C99 et c'est un tableau à longueur variable (VLA). Mais il y a des limitations dans leur utilisation, et je ne pense pas que le PO voulait utiliser un VLA. D'ailleurs, cette fonctionnalité possède le status "Broken" dans l'implantation actuelle de C99 par gcc. Je déconseille donc leur utilisation et je penses comme toi que l'allocation dynamique est plus appropriée ici.

    Thierry
    "The most important thing in the kitchen is the waste paper basket and it needs to be centrally located.", Donald Knuth
    "If the only tool you have is a hammer, every problem looks like a nail.", probably Abraham Maslow

    FAQ-Python FAQ-C FAQ-C++

    +

  4. #4
    Membre très actif

    Profil pro
    Étudiant
    Inscrit en
    Décembre 2004
    Messages
    499
    Détails du profil
    Informations personnelles :
    Âge : 39
    Localisation : France

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Décembre 2004
    Messages : 499
    Par défaut
    salut

    ça ne me parait pas très utile si tu recherches un mot assez court

    par exemple Développez

    tu lis toute ta chaine
    si tu tombres du un D ou un d tu regardes si après il y a un E ou un e o è ou ê ...

    en gros tu fais une fonction strcmp à ceci près que pour a e i o u y il ne prend pas en compte l'accent ni la casse

    l'automate sera ici une perte d'efficacité et de performance dans l'algo

    ça sera utile plus pour rechercher une chaine très longue

  5. #5
    Membre chevronné Avatar de corentin59
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    462
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 462
    Par défaut
    Citation Envoyé par zarbiman Voir le message
    Ce que je veux faire, c'est vérifier si "mot" est présent dans "motRecherche", et si possible en tenant compte des accents et des majuscules.
    Par exemple, si motRecherche = developpez.net et mot = Développez, je voudrais que ça matche...
    Si tu veux tenir compte des accents et des majuscules, ton exemple ne doit pas "matcher"

Discussions similaires

  1. [RegEx] Expression régulières : Balises <SCRIPT>
    Par Gwipi dans le forum Langage
    Réponses: 2
    Dernier message: 24/04/2006, 23h25
  2. Expression réguliére
    Par Mad_Max dans le forum Langages de programmation
    Réponses: 2
    Dernier message: 16/09/2003, 18h17
  3. [expression régulière] mon cerveau fait des noeuds..
    Par nawac dans le forum Algorithmes et structures de données
    Réponses: 7
    Dernier message: 27/05/2003, 10h06
  4. Expressions réguliéres
    Par Tooms dans le forum Langage
    Réponses: 4
    Dernier message: 06/12/2002, 18h42
  5. Réponses: 5
    Dernier message: 11/06/2002, 15h21

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