التابع regex.finditer()‎ في بايثون‎

من موسوعة حسوب


يعيد التابع كائنًا قابلًا للتكرار iterator ينتج عنه كائنات match لجميع حالات التطابق غير المتداخلة والناتجة من تطبيق التعبير النمطي المصرّف على السلسلة النصية المعطاة.

البنية العامة

regex.finditer(string[, pos[, endpos]])

المعاملات

string

السلسلة النصية التي سيبحث فيها التابع عن حالات التطابق.

pos

يحدّد هذا المعامل الاختياري الموقع الذي يبدأ منه التابع البحث في السلسلة النصية، ويأخذ القيمة الافتراضية 0. إن تحديد موقع بدء عملية البحث ليس مطابقًا تمامًا لعملية تقطيع السلسلة النصية، فالمحرف '^' يطابق في بداية السلسلة النصية وفي المواقع التي تأتي بعد محرف السطر الجديد، ولكن ليس بالضرورة في الموقع الذي يبدأ التابع منه عملية البحث.

endpos

يحدّد هذا المعامل الاختياري الموقع الذي ينتهي عنده التابع من البحث في السلسة النصية، وهذا يعني أنّ عملية البحث عن التطابقات ستجري على المحارف التي تقع ضمن النطاق الذي يبدأ بالموقع pos وينتهي بالموقع endpos - 1. إن كانت قيمة endpos أقل من قيمة pos فلن يكون هناك أي حالة تطابق

القيمة المعادة

يعيد الدالة كائنًا قابلًا للتكرار iterator ينتج عنه كائنات match لجميع حالات التطابق غير المتداخلة والناتجة من تطبيق التعبير النمطي المصرّف على السلسلة النصية المعطاة.

هذا التابع مطابق للدالة re.finditer()‎ ويستخدم التعبير النمطي المصرّف، ولكنّه يختلف عن الدالة في كونه يأخذ معاملين اختياريين هما pos و endpos والذي يحدّدان بداية ونهاية عملية البحث.

أمثلة

يبين المثال التالي طريقة استخدام التابع والنتائج المعادة منه:

>>> import re
>>> p = re.compile(r'\d+')
>>> iterator = p.finditer('12 drumers drumming, 11 ... 10 ...')
>>> iterator
<callable_iterator object at 0x7f07b66dd0b8>
>>> for match in iterator:
...     print(match.span())
...     
... 
(0, 2)
(21, 23)
(28, 30)

انظر أيضًا

مصادر