Maison >développement back-end >Golang >Comment gérer les caractères non-ASCII avec les limites Go Regex : une solution pour \'é\' et au-delà ?

Comment gérer les caractères non-ASCII avec les limites Go Regex : une solution pour \'é\' et au-delà ?

Patricia Arquette
Patricia Arquetteoriginal
2024-10-30 10:17:021073parcourir

How to Handle Non-ASCII Characters with Go Regex Boundaries: A Solution for

Go regexp Boundary with Non-ASCII Characters : Une modification Regex

Le traitement des caractères non-ASCII peut poser des défis lorsque vous travaillez avec les caractères réguliers de Golang expressions (regex). En particulier, l'option de limite « b », conçue pour correspondre aux limites des caractères, peut ne pas se comporter comme prévu lorsque vous rencontrez des caractères latins comme « é ». Ce problème se pose car "b" fonctionne exclusivement avec des caractères ASCII.

Pour résoudre ce problème, nous pouvons créer une limite personnalisée qui englobe une gamme plus large de caractères au-delà de l'ASCII. Voici une solution :

<code class="go">package main

import (
    "fmt"
    "regexp"
)

func main() {
    r, _ := regexp.Compile(`(?:\A|\s)(vis)(?:\s|\z)`)
    fmt.Println(r.MatchString("vis")) // Handle case without boundary
    fmt.Println(r.MatchString("re vis e"))
    fmt.Println(r.MatchString("revise"))
    fmt.Println(r.MatchString("révisé"))
}</code>

Explication :

Cette expression régulière modifiée utilise les remplacements suivants :

  • "b" est remplacé avec "(?:A|s)(?:s|z)".
  • "A" représente le début de la chaîne.
  • "z" représente la fin de la chaîne.
  • "s" représente un espace.

Cela permet à la limite de correspondre au début de la chaîne, à la fin de la chaîne ou aux caractères d'espacement. Les caractères latins comme "é" sont désormais considérés comme des caractères ordinaires et ne déclencheront pas de fausses correspondances de limites.

En modifiant l'option de limite, nous pouvons gérer efficacement les caractères latins et autres caractères non-ASCII dans les expressions régulières de Go, garantissant ainsi une précision comportement correspondant.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn