Designed by Derf !
116 en ligne   Boutique | Sites | Bar | Forum | PhpBB | Actu | Glossaire | Codes | Tips | Liens | Livres | Lettre  


 Recherche

 NewsLetter






   

L'objet REGEXP (1/2)

Les Expressions Régulières et JavaScript





Didier
Qu'est-ce que c'est encore que cette bête ?... En fait, un moyen simple, même si parfois obscur au premier abord, pour faire des recherches d'occurences dans une chaîne... Exemple :

Pour vérifier la validité de structure d'une adresse email saisie dans un formulaire :

Page 1  2  SUITE >> 
Télécharger tout le tutorial JavaScript/VBScript

function verif(email) { // vérif validité email par STRING
   var arobase = email.indexOf("@")
   var point = email.lastIndexOf(".")
   if((arobase < 3)||(point + 2 > email.length)
      ||(point < arobase+3)) return false
   return true
}
function verif(email) { // vérif validité email par REGEXP
   var reg = /^[a-z0-9._-]+@[a-z0-9.-]{2,}[.][a-z]{2,3}$/
   return (reg.exec(email)!=null)
}

Evidemment comme ça, à froid, c'est illisible... alors détails :
  • var reg = /blablabla/ définit un masque de recherche
  • reg.exec(votrechaîne) cherche les occurences du masque dans votre chaîne et retourne ce qui a été trouvé ou null
  • "blablabla" enfin se décompose dans notre exemple de la manière suivante :

    • ^ : depuis le début de la chaîne
    • [a-z0-9.-_]+ : cherche au moins 1 caractère spécifié (de "a" à "z" ou "0" à "9" ou "." ou "-" ou "_")
    • @ : suivis de l'arobase
    • [a-z0-9]{2,} : suivis d'au-moins 2 caractères spécifiés (de "a" à "z" ou "0" à "9")
    • [.] : suivis d'un point (entre crochets car spécial dans regexp)
    • [a-z]{2,3} : suivis de 2 à 3 caractères spécifiés (de "a" à "z")
    • $ : et la chaîne doit être terminée
Note : + signifie "au moins 1 fois le caractère précédent" équivalent à {1,}

Du coup vous voyez qu'il est facile de tester si l'internaute a bien tapé...
  • un nombre entier : var reg = /^\d+$/
    ( \d équivaut à [0-9] )
  • ou un décimal : var reg = /^\d+[.]\d+$/
  • ou un nombre (entier ou décimal) : var reg = /^\d+[.]?\d*$/
    ( * signifie "0 ou plusieurs fois" et ? signifie "0 ou 1 fois" )
  • ou un décimal finissant par ".5" (demandé par un visiteur) var reg = /^\d*[.]5$/
  • ... etc

L'objet RegExp, comme ceux utilisés dans les autres fiches, est décrit dans la doc JVScript ! Suivent quelques-uns des caractères pouvant constituer ce masque...
CaractèreExemplesCommentaire
^  $   Début et fin de la saisie
[ ] [asp]   [0-9]   [a-zA-Z] Liste de caractères
[^ ] [^asp]   [^0-9]   [^a-zA-Z] Liste de caractères exclus
(modele)   Modèle
x|y (f|z)oo : marche pour foot ou zoo x ou y
*   Le caractère précédent apparaît 0 ou plusieurs fois
+   Le caractère précédent apparaît 1 ou plusieurs fois
?   Le caractère précédent apparaît 0 ou 1 fois
{n}   Le caractère précédent apparaît exactement n fois
{n,}   Le caractère précédent apparaît au moins n fois
{n,m}   Le caractère précédent apparaît de n à m fois
\ \\ --> \     \( --> (     \) --> )
\n --> nouvelle ligne
\f --> saut de page
\t --> tabulation
Le caractère suivant est spécial
\b   Fin d'un mot
\B   Pas à la fin d'un mot
\xHH \x41 <--> A Code hexadécimal d'un caractère
\s \s <--> [ \f\n\r\t\v] Tout caractère séparateur
\S \S <--> [^ \f\n\r\t\v] Tout caractère non séparateur
\ autres \d <--> [0-9]
\D <--> [^0-9]
\w <--> [A-Za-z0-9_]
\W <--> [^A-Za-z0-9_]
Raccourcis

REMARQUES
  • On peut déclarer autrement une variable RegExp : var reg = new RegExp("blablabla")

  • Un paramètre supplémentaire (commutateur) peut être ajouté :
    var reg = /blablabla/commut ou var reg = new RegExp("blablabla","commut")
    avec 3 valeurs possibles pour commut :
    • i : ignorer la casse (diff maj/min) ;
    • g : recherche globale (toutes les occurences) ;
    • gi : recherche globale ignorant la casse ;


  • la 1ère occurence trouvée dans la chaîne est à RegExp.index ou -1 si pas trouvé...

  • On peut aussi remplacer les occurences par une autre sous-chaîne : chaine.replace(reg, souschaine)

  • On peut aussi décomposer une chaîne en un tableau : chaine.split(reg)

  • On peut enfin obtenir un tableau des résultats de recherche avec exec ou match... l'élément 0 contient les derniers caractères retenus et les autres éléments (1 à 9) les correspondances des modèles entre parenthèses dans l'expression régulière.
Page 1  2  SUITE >> 

Didier le 30/05/2003 (154 933 hits)
Didier Téléchargez gratuitement et légalement des logiciels Microsoft ! Si, si ;)
  • Visual Studio 2010
  • Office 2010
  • Expression Studio 3
  • SQL Server 2008
  • et d'autres...
Au fil des news  
Magazines - Le N°128 de Programmez est disponible
Magazines - Le N°127 de Programmez est disponible
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 6
Pour continuer dans le même style, je vous propose une suite au précédent article. Rechercher tous ...
Adobe - Adobe Photoshop.com Mobile pour iPhone 1.1
JavaScript - Ajouter une page dans vos favorites
Dreamweaver CS4 + Php + Mysql - Trucs et Astuces - Part 5 -
Je vous propose cette fois deux astuces. Comment exporter une feuille de style avec l'aide de ...
SharePoint Personalization Site Links - Les liens personnalisés des MySite SharePoint
Nous avons vu dans les articles précédents comment agrémenter les pages de recherche afin de ...
Magazines - Le n°126 de Programmez est disponible
Outils - Traducteur en ligne automatique pour site web
Adobe - Adobe Photoshop.com Mobile pour Iphone
Magazines - Le n°125 de Programmez est disponible
Adobe - Adobe AIR 2 et Flash Player 10.1version bêta
Les conférences autour des technologies Microsoft - Liste non exhaustive des grands évènements
Nous allons essayer de regrouper un grand nombre des évènements autour des technologies Microsoft ...
Magazines - Le n°124 de Programmez est disponible
PHP - Forum PHP 2009
Composants - eFace - XAML en Java
WPF - Désactiver le bouton de réduction d'une fenêtre
Magazines - Le n°123 de Programmez est disponible
Magazines - Le n°122 de Programmez est disponible
Auditer une ferme SharePoint - Assurer le bon fonctionnement de SharePoint
Dans le cadre de la bonne gestion de son environnement SharePoint, il est utile de faire un ...
SQL Server 2008 Report Builder 2.0 - Installation et utilisation de Report Builder 2.0
Dans le cadre de la création de rapports pour SQL Server Reporting Services 2008, un outil est ...
Magazines - Le HS N° 1 de Web Design est disponible
Adobe - Adobe propose en Open Source les frameworks.....
Outils - EntityBuilder
CSharp - Sérialisation XML de vos objets
Magazines - Le n°121 de Programmez est disponible
Adobe - Adobe annonce MAX 2009 !
Outils - WhoIs
[MAJ] Dreamweaver MX + Php + MySql - Les formulaires - partie 3
Mise à jour du code, par DB 77, affichage du code erreur, dans la page erreur.php, traduction des ...
PHP - News avec photo - Système de gestion - affichage
Gestion - Administration - Affichage d'une "News", "Actualité", "Info", ... avec : - mise en forme ...
Outils - Crypt
Dreamweaver Php Mysql - Région répétée imbriquée
Je rebondis, sur un post du forum, pour vous montrer comment obtenir grâce à l'extension Simulated ...
Magazines - Le n° 120 de Programmez est disponible
Gérer les bases de contenu SharePoint - Gérer la croissance du volume des données
Dans le cadre de la gestion quotidienne de ferme SharePoint, il existe une partie qu'il faut ...
PHP - Le Coach PHP sur Visual Studio
.NET - Ecrire une application .NET utilisant MySQL
PHP - Utilisation de PHP dans le monde Microsoft
Magazines - Le n° 119 de Programmez est disponible
Adobe - Adobe annonce Photoshop Marketplace
[MAJ] Tutoriel AJAX simple - En avant vers le WEB2.0
Mis à jour le 20/04/2009
Tutorial : HTML | Scripting | ASP-PHP | ASP.net | SQL Server | XML
Sharepoint | XAML | Pocket | Dreamweaver | VML | Divers
  Scripts : Scripting | ASP-PHP | ASP.net | Divers
  Boutique | Annuaire | Bannières | Météo | Tribune | Partenariats
v3b © Didier 2003   
 

Corpo Sciences de Reims Partitions gratuites Carte, météo, annonces
 TechNet MVP Groupes Utilisateurs Microsoft ASP-magazine DotNet Project