الفرق بين المراجعتين لصفحة: «Python/iterators»
أنشأ الصفحة ب'لعلّك لاحظت أن بالإمكان المرور على عناصر معظم الكائنات الحاوية (container objects) (مثل Python/list|القوا...' |
لا ملخص تعديل |
||
(1 مراجعات متوسطة بواسطة نفس المستخدم غير معروضة) | |||
سطر 1: | سطر 1: | ||
<noinclude>{{DISPLAYTITLE:المكرِّرات Iterators في بايثون}}</noinclude> | |||
لعلّك لاحظت أن بالإمكان المرور على عناصر معظم الكائنات الحاوية (container objects) (مثل [[Python/list|القوائم]] و<nowiki/>[[Python/dict|القواميس]] و<nowiki/>[[Python/str|السلاسل النصية]] وغيرها...) باستخدام عبارة <code>[[Python/for|for]]</code>:<syntaxhighlight lang="python3"> | لعلّك لاحظت أن بالإمكان المرور على عناصر معظم الكائنات الحاوية (container objects) (مثل [[Python/list|القوائم]] و<nowiki/>[[Python/dict|القواميس]] و<nowiki/>[[Python/str|السلاسل النصية]] وغيرها...) باستخدام عبارة <code>[[Python/for|for]]</code>:<syntaxhighlight lang="python3"> | ||
for element in [1, 2, 3]: | for element in [1, 2, 3]: | ||
سطر 10: | سطر 11: | ||
for line in open("myfile.txt"): | for line in open("myfile.txt"): | ||
print(line, end='') | print(line, end='') | ||
</syntaxhighlight>تستدعي عبارة <code>[[Python/for|for]]</code> خلف الكواليس الدالة <code>iter()</code> على الكائن الحاوي، فتعيد الدالة كائن تكرار (iterator object) يعرّف التابع <code>__next__()</code> الذي يستطيع الوصول إلى عنصر واحد في الكائن الحاوي كلّ مرة. عند انتهاء العناصر يطلق التابع <code>__next__()</code> الاستثناء <code>StopIteration</code> والذي يوقف عمل حلقة <code>[[Python/for|for]]</code>. يمكن استدعاء التابع <code>__next__()</code> باستخدام الدالة الداخلية <code>next()</code>، والمثال التالي يوضح العملية برمّتها:<syntaxhighlight lang="python3"> | </syntaxhighlight>تستدعي عبارة <code>[[Python/for|for]]</code> خلف الكواليس الدالة <code>[[Python/iter|iter()]]</code> على الكائن الحاوي، فتعيد الدالة كائن تكرار (iterator object) يعرّف التابع <code>__next__()</code> الذي يستطيع الوصول إلى عنصر واحد في الكائن الحاوي كلّ مرة. عند انتهاء العناصر يطلق التابع <code>__next__()</code> الاستثناء <code>StopIteration</code> والذي يوقف عمل حلقة <code>[[Python/for|for]]</code>. يمكن استدعاء التابع <code>__next__()</code> باستخدام الدالة الداخلية <code>[[Python/next|next()]]</code>، والمثال التالي يوضح العملية برمّتها:<syntaxhighlight lang="python3"> | ||
>>> s = 'abc' | >>> s = 'abc' | ||
>>> it = iter(s) | >>> it = iter(s) | ||
سطر 26: | سطر 27: | ||
next(it) | next(it) | ||
StopIteration | StopIteration | ||
</syntaxhighlight>من السهل تعديل آلية عمل المكرّرات في [[Python/class|الأصناف]] التي يعرّفها المستخدم، فغاية ما في الأمر هو تعريف تابع <code>__iter__()</code> الذي يعيد كائنًا مع تابع <code>__next__()</code>. إن عَرَّفَ الصنف التابع <code>__next__()</code> فيمكن للتابع <code>__iter__()</code> حينئذ أن يعيد <code>self</code>:<syntaxhighlight lang="python3"> | </syntaxhighlight>من السهل تعديل آلية عمل المكرّرات في [[Python/class|الأصناف]] التي يعرّفها المستخدم، فغاية ما في الأمر هو تعريف تابع <code>__iter__()</code> الذي يعيد كائنًا مع تابع <code>__next__()</code>. إن عَرَّفَ الصنف التابع <code>__next__()</code> فيمكن للتابع <code>__iter__()</code> حينئذ أن يعيد القيمة <code>self</code>:<syntaxhighlight lang="python3"> | ||
class Reverse: | class Reverse: | ||
"""مكرِّر يمرّ على عناصر التسلسل عكسيًا""" | """مكرِّر يمرّ على عناصر التسلسل عكسيًا""" |
المراجعة الحالية بتاريخ 13:05، 18 مايو 2018
لعلّك لاحظت أن بالإمكان المرور على عناصر معظم الكائنات الحاوية (container objects) (مثل القوائم والقواميس والسلاسل النصية وغيرها...) باستخدام عبارة for
:
for element in [1, 2, 3]:
print(element)
for element in (1, 2, 3):
print(element)
for key in {'one':1, 'two':2}:
print(key)
for char in "123":
print(char)
for line in open("myfile.txt"):
print(line, end='')
تستدعي عبارة for
خلف الكواليس الدالة iter()
على الكائن الحاوي، فتعيد الدالة كائن تكرار (iterator object) يعرّف التابع __next__()
الذي يستطيع الوصول إلى عنصر واحد في الكائن الحاوي كلّ مرة. عند انتهاء العناصر يطلق التابع __next__()
الاستثناء StopIteration
والذي يوقف عمل حلقة for
. يمكن استدعاء التابع __next__()
باستخدام الدالة الداخلية next()
، والمثال التالي يوضح العملية برمّتها:
>>> s = 'abc'
>>> it = iter(s)
>>> it
<iterator object at 0x00A1DB50>
>>> next(it)
'a'
>>> next(it)
'b'
>>> next(it)
'c'
>>> next(it)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
next(it)
StopIteration
من السهل تعديل آلية عمل المكرّرات في الأصناف التي يعرّفها المستخدم، فغاية ما في الأمر هو تعريف تابع __iter__()
الذي يعيد كائنًا مع تابع __next__()
. إن عَرَّفَ الصنف التابع __next__()
فيمكن للتابع __iter__()
حينئذ أن يعيد القيمة self
:
class Reverse:
"""مكرِّر يمرّ على عناصر التسلسل عكسيًا"""
def __init__(self, data):
self.data = data
self.index = len(data)
def __iter__(self):
return self
def __next__(self):
if self.index == 0:
raise StopIteration
self.index = self.index - 1
return self.data[self.index]
>>> rev = Reverse('spam')
>>> iter(rev)
<__main__.Reverse object at 0x00A1DB50>
>>> for char in rev:
... print(char)
...
m
a
p
s
مصادر
- صفحة Classes في توثيق بايثون الرسمي.