Maison >développement back-end >Tutoriel Python >Comment les expressions régulières de Python peuvent-elles trouver des correspondances qui se chevauchent ?

Comment les expressions régulières de Python peuvent-elles trouver des correspondances qui se chevauchent ?

DDD
DDDoriginal
2024-12-17 08:32:24410parcourir

How Can Python's Regular Expressions Find Overlapping Matches?

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!

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