الفرق بين المراجعتين ل"Python/iterators"

من موسوعة حسوب
اذهب إلى التنقل اذهب إلى البحث
 
سطر 11: سطر 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)
سطر 27: سطر 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 في توثيق بايثون الرسمي.