Recherche de correspondances qui se chevauchent avec des expressions régulières
En Python, à l'aide du module re, la recherche de toutes les correspondances qui se chevauchent d'un modèle peut être obtenue via le utilisation d'une analyse anticipée, qui capture les correspondances souhaitées tout en conservant techniquement la correspondance réelle sans chevauchement.
Capture d'une anticipation de groupe :
La clé pour capturer des correspondances qui se chevauchent est d'utiliser un groupe de capture dans une assertion d'anticipation. La recherche anticipée capture le texte souhaité, mais la correspondance réelle est la sous-chaîne de largeur nulle avant la recherche anticipée. Cela permet des correspondances techniquement sans chevauchement :
import re s = "123456789123456789" matches = re.finditer(r'(?=(\d{10}))', s) # 10-digit number series results = [int(match.group(1)) for match in matches] print(results) # [1234567891, 2345678912, 3456789123, ...]
Dans cet exemple, le modèle (d{10}) correspond à des séquences à 10 chiffres, tandis que l'anticipation (?=) capture et affirme la présence de ces matchs. Les correspondances sont ensuite converties en nombres entiers à l'aide de int(match.group(1)).
Cette technique permet une identification efficace de toutes les correspondances qui se chevauchent au sein d'une chaîne plus grande.
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!