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

 .NET Discussion :

Générer toute les combinaisons valide pour une expression régulière


Sujet :

.NET

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 312
    Points : 184
    Points
    184
    Par défaut Générer toute les combinaisons valide pour une expression régulière
    Bonjour, j'aimerai pouvoir générer une collection de string contenant toute les combinaisons valides pour une expression régulière que je passerai en paramètre.
    Les chaines à tester, seront uniquement constituées de combinaison de chiffres de tailles variables, avec une taille maximum absolue.

    J'ai fait un prototype qui genere des nombres de façon incrémentale et qui test chaque entré. Malheureusement, ce porceder dure un temps beaucoup trop grand.
    Y a t il un autre moyen que celui-ci, j'ai vu qu'un paquet Perl etait succeptible de faire la même chose.

    merci d'avance

  2. #2
    Membre expérimenté
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Points : 1 454
    Points
    1 454
    Billets dans le blog
    9
    Par défaut
    tu met ta collection de string dans une liste et avec un foreach tu compare les chaine d'entrer avec la liste de string une fois tu trouve ce que tu cherche tu met return;

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 312
    Points : 184
    Points
    184
    Par défaut
    Citation Envoyé par charouel Voir le message
    tu met ta collection de string dans une liste et avec un foreach tu compare les chaine d'entrer avec la liste de string une fois tu trouve ce que tu cherche tu met return;
    oui mais ma collection irai de "0" à "99999999999999" a a vu de nez y en a pour un paquet de temps, y a t il un moyen plus simlpe que de passer par une boucle ?

  4. #4
    Membre expérimenté
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Points : 1 454
    Points
    1 454
    Billets dans le blog
    9
    Par défaut
    Il faut avoir une combinaison au moin
    Si par exemple ta valeur cava etre dans le premier ou dans les dernier type
    tu devise la partie recherche en 4 ou 8 bloque de 1 a 500000 puis de 5000001 a 1000000000000 puis de ......... et etc ...

  5. #5
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 312
    Points : 184
    Points
    184
    Par défaut
    Citation Envoyé par charouel Voir le message
    Il faut avoir une combinaison au moin
    Si par exemple ta valeur cava etre dans le premier ou dans les dernier type
    tu devise la partie recherche en 4 ou 8 bloque de 1 a 500000 puis de 5000001 a 1000000000000 puis de ......... et etc ...
    C'est un peu compliqué car globalement ce sont des numéros de téléphones de plusieurs, et le but est d'identifier des plages de numéro pour chaque pays dont les règles sont toutes différentes.

    Si pour la France cela est assez simple car les plages sont restreinte (ou peut sauter par groupe de 100 voir de 1000 sans problème), pour d'autres pays cela peut être compliqué(certaines plages sont très complexes et possèdent des sous plages de validité)

  6. #6
    Membre expérimenté
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Points : 1 454
    Points
    1 454
    Billets dans le blog
    9
    Par défaut
    les numéro de téléphone sont repartie pour chaque pays tu trouve un indice de 4 chiffre pour la France par exemple soit 0033 ou +33 et après tu trouve le numéro qui indique la région 01, 02, 03. Les chose sont plus facile maintenant

  7. #7
    Membre expérimenté
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Points : 1 454
    Points
    1 454
    Billets dans le blog
    9
    Par défaut
    Tu peut utilisé linq to Sql ce plus facile et plus rapide que for each

  8. #8
    Membre habitué
    Profil pro
    Inscrit en
    Mars 2002
    Messages
    312
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2002
    Messages : 312
    Points : 184
    Points
    184
    Par défaut
    Citation Envoyé par charouel Voir le message
    les numéro de téléphone sont repartie pour chaque pays tu trouve un indice de 4 chiffre pour la France par exemple soit 0033 ou +33 et après tu trouve le numéro qui indique la région 01, 02, 03. Les chose sont plus facile maintenant
    Si pour la France cela est assez simple car les plages sont restreinte (ou peut sauter par groupe de 100 voir de 1000 sans problème), pour d'autres pays cela peut être compliqué(certaines plages sont très complexes et possèdent des sous plages de validité)

  9. #9
    Membre expérimenté
    Avatar de charouel
    Homme Profil pro
    Freelance
    Inscrit en
    Mars 2009
    Messages
    618
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mars 2009
    Messages : 618
    Points : 1 454
    Points
    1 454
    Billets dans le blog
    9
    Par défaut
    Tu peux essayé Linq to SQL

Discussions similaires

  1. Réponses: 4
    Dernier message: 14/03/2014, 18h03
  2. Réponses: 0
    Dernier message: 04/02/2013, 13h03
  3. Générer toutes les combinaisons d'une suite
    Par man_coef dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 28/04/2008, 18h56
  4. Réponses: 16
    Dernier message: 20/10/2006, 16h31

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