Points clés
- Catégorie
- Development
- Types d’entrée
- textarea, text, number, select, checkbox
- Type de sortie
- json
- Couverture des échantillons
- 4
- API disponible
- Yes
Vue d’ensemble
Cet outil de benchmark vous permet de comparer les performances de plusieurs expressions régulières, d'identifier les goulots d'étranglement et de détecter les cas dégénérés pour optimiser vos modèles regex.
Quand l’utiliser
- •Lorsque vous devez choisir le modèle regex le plus performant parmi plusieurs options.
- •Quand vous rencontrez des lenteurs dans le traitement de texte avec des expressions régulières.
- •Pour vérifier la robustesse de vos regex contre des entrées extrêmes ou malveillantes.
Comment ça marche
- •Entrez plusieurs modèles regex et des chaînes de test dans les champs dédiés.
- •Configurez le nombre d'itérations et les phases d'échauffement pour des mesures précises.
- •Exécutez le benchmark pour obtenir des statistiques détaillées et une classification de performance.
- •Recevez des recommandations pour optimiser vos regex basées sur les résultats.
Cas d’usage
Exemples
1. Comparer deux regex pour valider des numéros de téléphone
- Contexte
- Un développeur doit implémenter une validation de numéros de téléphone dans une application mobile.
- Problème
- Le modèle regex actuel est trop lent et impacte l'expérience utilisateur.
- Comment l’utiliser
- Entrez les deux modèles regex dans 'Modèles Regex' et des exemples de numéros dans 'Entrées de Test'.
- Configuration d’exemple
-
Réglez les itérations à 500 et les drapeaux à 'g' pour correspondances globales. - Résultat
- Le benchmark révèle que le modèle simplifié est 30% plus rapide avec une précision acceptable.
2. Détecter un retour catastrophique dans une regex de parsing
- Contexte
- Une expression régulière utilisée pour extraire des balises HTML ralentit sur de longues chaînes.
- Problème
- Identifier si la regex cause un retour catastrophique qui ralentit le traitement.
- Comment l’utiliser
- Entrez la regex complexe et des chaînes HTML longues dans les champs correspondants. Activez 'Inclure les Cas Dégénérés'.
- Résultat
- L'outil détecte un cas dégénéré et suggère de remplacer '.*' par '[^>]*' pour éviter le retour.
Tester avec des échantillons
regexHubs associés
FAQ
Comment interpréter les résultats du benchmark ?
Les résultats incluent le temps moyen, min, max et médian, ainsi qu'une classification de performance (rapide, moyen, lent, très lent).
Quels drapeaux regex puis-je utiliser ?
Vous pouvez spécifier des drapeaux comme 'gi' pour global et insensible à la casse, ou 'm' pour multiligne.
Puis-je tester des regex pour Python ?
Oui, sélectionnez 'Python (Simulé)' dans le champ 'Moteur Regex' pour une simulation des performances.
Comment éviter les cas dégénérés ?
Utilisez des groupes atomiques ou des quantificateurs possesifs, et évitez les quantificateurs imbriqués.
Combien d'itérations sont recommandées ?
Commencez avec 1000 itérations pour un équilibre entre précision et vitesse, ajustez selon vos besoins.