Maison >développement back-end >Tutoriel Python >Comment les expressions régulières de Python peuvent-elles trouver des correspondances qui se chevauchent ?
Correspondances superposées avec des expressions régulières en Python
Trouver toutes les occurrences d'un modèle, même lorsqu'elles se chevauchent, peut être un défi. Cependant, en utilisant la puissance des expressions régulières, vous pouvez résoudre ce problème sans effort.
Par exemple, supposons que vous deviez extraire chaque série de nombres à 10 chiffres d'une chaîne numérique plus grande. Au lieu de vous limiter à des correspondances qui ne se chevauchent pas, vous pouvez adopter des chevauchements pour rassembler une liste complète.
Pour y parvenir, la clé est d'employer un groupe de capture dans le cadre d'une analyse prospective. L'anticipation capturera la séquence d'intérêt souhaitée, mais comme la correspondance réelle est la sous-chaîne de largeur nulle avant l'anticipation, les correspondances ne se chevauchent pas.
import re s = "123456789123456789" matches = re.finditer(r'(?=(\d{10}))', s) results = [int(match.group(1)) for match in matches] print(results) # [1234567891, 2345678912, 3456789123, ...]
Cette approche donnera une liste contenant les chevauchements. correspond, vous permettant de capturer chaque instance de la séquence de chiffres spécifiée dans la chaîne d'origine.
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!