The expression (sum(row) for row in M) creates what's called a generator. This generator will evaluate the expression (sum(row)) once for each row in M. However, the generator doesn't do anything yet, we've just set it up.

The statement next(G) actually runs the generator on M. So, if you run next(G) once, you'll get the sum of the first row. If you run it again, you'll get the sum of the second row, and so on.

>>> M = [[1,2,3],
...      [4,5,6],
...      [7,8,9]]
>>> 
>>> G = (sum(row) for row in M) # create a generator of row sums
>>> next(G) # Run the iteration protocol
6
>>> next(G)
15
>>> next(G)
24

See also:

  • Documentation on generators
  • Documentation on yield expressions (with some info about generators)
Answer from jtbandes on Stack Overflow
🌐
W3Schools
w3schools.com › python › ref_func_next.asp
Python next() Function
Python Examples Python Compiler Python Exercises Python Quiz Python Challenges Python Server Python Syllabus Python Study Plan Python Interview Q&A Python Bootcamp Python Certificate Python Training · ❮ Built-in Functions · Create an iterator, and print the items one by one: mylist = iter(["apple", "banana", "cherry"]) x = next(mylist) print(x) x = next(mylist) print(x) x = next(mylist) print(x) Try it Yourself » ·
🌐
Python documentation
docs.python.org › 3 › library › functions.html
Built-in Functions — Python 3.14.3 documentation
February 27, 2026 - Retrieve the next item from the iterator by calling its __next__() method. If default is given, it is returned if the iterator is exhausted, otherwise StopIteration is raised. ... This is the ultimate base class of all other classes.
🌐
Programiz
programiz.com › python-programming › methods › built-in › next
Python next()
The next() function returns the next item from the iterator. In this tutorial, we will learn about the Python next() function in detail with the help of examples.
🌐
GeeksforGeeks
geeksforgeeks.org › python › python-next-method
Python next() method - GeeksforGeeks
December 19, 2025 - The next() function returns the next item from an iterator. If there are no more items, it raises a StopIteration error, unless you provide a default value.
🌐
Real Python
realpython.com › ref › builtin-functions › next
next() | Python’s Built-in Functions – Real Python
The .__next__() method processes the current number and returns its square value. When there are no more items, .__next__() raises the StopIteration exception. ... In this tutorial, you'll learn what iterators and iterables are in Python.
🌐
Python Morsels
pythonmorsels.com › next
Python's next() function - Python Morsels
July 17, 2023 - That function manually calls next on iterators corresponding to each of the given iterables, one after the other. If you're curious about that sentinel = object() line, see Unique sentinel values in Python.
🌐
Tutorialspoint
tutorialspoint.com › python › python_next_function.htm
Python next() Function
The Python next() function is used to iterate through the contents of a Python iterator object, an object representing a stream of data. If you pass an iterator object to this function, it returns the next item in it.
Find elsewhere
Top answer
1 of 2
79

The expression (sum(row) for row in M) creates what's called a generator. This generator will evaluate the expression (sum(row)) once for each row in M. However, the generator doesn't do anything yet, we've just set it up.

The statement next(G) actually runs the generator on M. So, if you run next(G) once, you'll get the sum of the first row. If you run it again, you'll get the sum of the second row, and so on.

>>> M = [[1,2,3],
...      [4,5,6],
...      [7,8,9]]
>>> 
>>> G = (sum(row) for row in M) # create a generator of row sums
>>> next(G) # Run the iteration protocol
6
>>> next(G)
15
>>> next(G)
24

See also:

  • Documentation on generators
  • Documentation on yield expressions (with some info about generators)
2 of 2
10

If you've come that far, then you should already know how a common for-in statement works.

The following statement:

for row in M: print row

would see M as a sequence of 3 rows (sub sequences) consisting of 3 items each, and iterate through M, outputting each row on the matrix:

[1, 2, 3]
[4, 5, 6]
[7, 8, 9]

You knew that, well...

You can see Generators just as some syntactic sugar around for-in loops. Forget about the sum() call, and type something like this on IDLE:

G = (row for row in M)
print G
for a in G: print a

You see, the Generator cannot be directly represented as text, not just as a sequence can be. But, you can iterate through a Generator as if it were a sequence.

You'll find some big differences then, but the basics are that you can use a generator not to return just the value of each item in the sequence, but the result of any expression. In the tutorial's example, the expression is sum(row).

Try the following and see what happens:

G = ("("+str(row[2])+";"+str(row[1])+";"+str(row[0])+")" for row in M)
G.next()
G.next()
G.next()
🌐
Pierian Training
pieriantraining.com › home › understanding the ‘next’ keyword in python
Understanding the 'next' Keyword in Python - Pierian Training
April 28, 2023 - When we call the `next()` function on an iterator object, it returns the next value from the sequence. If there are no more elements, it raises the `StopIteration` exception. It is important to note that once an iterator has reached its end, ...
🌐
Codecademy
codecademy.com › docs › python › built-in functions › next()
Python | Built-in Functions | next() | Codecademy
July 8, 2025 - In Python, the next() function returns the next element from an iterator object.
🌐
iO Flood
ioflood.com › blog › python-next
Python next() Function Guide (With Examples)
June 12, 2024 - Using the next() function in Python programming is crucial while automating tasks at IOFLOOD, as it allows sequential access to elements in an iterator. In our experience, the next() function streamlines data traversal and facilitates efficient ...
🌐
Scaler
scaler.com › home › topics › next() in python | python next() function
next() in Python | Python next() Function - Scaler Topics
March 11, 2022 - The next() function in python programming is used to get the next item from a collection of values. The next() takes two values as arguments namely - iterator and default-value.
🌐
FavTutor
favtutor.com › blogs › next-function-python
Python next() function: Syntax, Example & Advantages
April 27, 2023 - The next() function is an in-built function in Python that is used on iterating operations and helps to return the next item from the iterators. The next item in the collection is fetched using this method.
🌐
Tutorialspoint
tutorialspoint.com › python › file_next.htm
Python File next() Method
The Python File next() method returns the next input line with respect to the current position of the file pointer in a file. This method in Python is used in an iterator, typically in a loop, where it is called repeatedly and all the lines ...
🌐
Python
peps.python.org › pep-3114
PEP 3114 – Renaming iterator.next() to iterator.__next__() | peps.python.org
March 4, 2007 - The iterator protocol in Python 2.x consists of two methods: __iter__() called on an iterable object to yield an iterator, and next() called on an iterator object to yield the next item in the sequence.
🌐
Initial Commit
initialcommit.com › blog › python-next-function
Python next() Function with Examples | Initial Commit
It is used on iterators in Python (which we'll discuss later), specifically to get items from those iterators. You likely have used the next() function in Python without even knowing it since it is used behind the scenes in For loops, to iterate through items.
Top answer
1 of 3
55

The special methods __iter__ and __next__ are part of the iterator protocol to create iterator types. For this purpose, you have to differentiate between two separate things: Iterables and iterators.

Iterables are things that can be iterated, usually, these are some kind of container elements that contain items. Common examples are lists, tuples, or dictionaries.

In order to iterate an iterable, you use an iterator. An iterator is the object that helps you iterate through the container. For example, when iterating a list, the iterator essentially keeps track of which index you are currently at.

To get an iterator, the __iter__ method is called on the iterable. This is like a factory method that returns a new iterator for this specific iterable. A type having a __iter__ method defined, turns it into an iterable.

The iterator generally needs a single method, __next__, which returns the next item for the iteration. In addition, to make the protocol easier to use, every iterator should also be an iterable, returning itself in the __iter__ method.

As a quick example, this would be a possible iterator implementation for a list:

Copyclass ListIterator:
    def __init__ (self, lst):
        self.lst = lst
        self.idx = 0

    def __iter__ (self):
        return self

    def __next__ (self):
        try:
            item = self.lst[self.idx]
        except IndexError:
            raise StopIteration()
        self.idx += 1
        return item

The list implementation could then simply return ListIterator(self) from the __iter__ method. Of course, the actual implementation for lists is done in C, so this looks a bit different. But the idea is the same.

Iterators are used invisibly in various places in Python. For example a for loop:

Copyfor item in lst:
    print(item)

This is kind of the same to the following:

Copylst_iterator = iter(lst) # this just calls `lst.__iter__()`
while True:
    try:
        item = next(lst_iterator) # lst_iterator.__next__()
    except StopIteration:
        break
    else:
        print(item)

So the for loop requests an iterator from the iterable object, and then calls __next__ on that iterable until it hits the StopIteration exception. That this happens under the surface is also the reason why you would want iterators to implement the __iter__ as well: Otherwise you could never loop over an iterator.


As for generators, what people usually refer to is actually a generator function, i.e. some function definition that has yield statements. Once you call that generator function, you get back a generator. A generator is esentially just an iterator, albeit a fancy one (since it does more than move through a container). As an iterator, it has a __next__ method to “generate” the next element, and a __iter__ method to return itself.


An example generator function would be the following:

Copydef exampleGenerator():
    yield 1
    print('After 1')
    yield 2
    print('After 2')

The function body containing a yield statement turns this into a generator function. That means that when you call exampleGenerator() you get back a generator object. Generator objects implement the iterator protocol, so we can call __next__ on it (or use the the next() function as above):

Copy>>> x = exampleGenerator()
>>> next(x)
1
>>> next(x)
After 1
2
>>> next(x)
After 2
Traceback (most recent call last):
  File "<pyshell#10>", line 1, in <module>
    next(x)
StopIteration

Note that the first next() call did not print anything yet. This is the special thing about generators: They are lazy and only evaluate as much as necessary to get the next item from the iterable. Only with the second next() call, we get the first printed line from the function body. And we need another next() call to exhaust the iterable (since there’s not another value yielded).

But apart from that laziness, generators just act like iterables. You even get a StopIteration exception at the end, which allows generators (and generator functions) to be used as for loop sources and wherever “normal” iterables can be used.

The big benefit of generators and their laziness is the ability to generate stuff on demand. A nice analogy for this is endless scrolling on websites: You can scroll down item after after (calling next() on the generator), and every once in a while, the website will have to query a backend to retrieve more items for you to scroll through. Ideally, this happens without you noticing. And that’s exactly what a generator does. It even allows for things like this:

Copydef counter():
    x = 0
    while True:
        x += 1
        yield x

Non-lazy, this would be impossible to compute since this is an infinite loop. But lazily, as a generator, it’s possible to consume this iterative one item after an item. I originally wanted to spare you from implementing this generator as a fully custom iterator type, but in this case, this actually isn’t too difficult, so here it goes:

Copyclass CounterGenerator:
    def __init__ (self):
        self.x = 0

    def __iter__ (self):
        return self

    def __next__ (self):
        self.x += 1
        return self.x
2 of 3
5

Why is __next__ only available to list but only to __iter__() and mygen but not mylist. How does __iter__() call __next__ when we are stepping through the list using list-comprehension.

Because lists have a separate object that is returned from iter to handle iteration, this objects __iter__ is consecutively called.

So, for lists:

Copyiter(l) is l # False, returns <list-iterator object at..>

While, for generators:

Copyiter(g) is g # True, its the same object

In looping constructs, iter is first going to get called on the target object to be looped over. iter calls __iter__ and an iterator is expected to be returned; its __next__ is called until no more elements are available.

What is a method-wrapper and what does it do? How is it applied here: in mygen() and __iter__()?

A method wrapper is, if I'm not mistaken, a method implemented in C. Which is what both these iter(list).__iter__ (list is an object implemented in C) and gen.__iter__ (not sure here but generators are probably too) are.

If __next__ is what both generator and iterator provide (and their sole properties) then what is the difference between generator and iterator?

A generator is an iterator, as is the iterator provided from iter(l). It is an iterator since it provides a __next__ method (which, usually, when used in a for loop it is capable of providing values until exhausted).

🌐
Python Reference
python-reference.readthedocs.io › en › latest › docs › file › next.html
next — Python Reference (The Right Way) 0.1 documentation
>>> f = open(r'C:\aiw.txt') >>> f.next() " ALICE'S ADVENTURES IN WONDERLAND\n" >>> f.next() '\n' >>> f.next() ' Lewis Carroll\n'
🌐
Vultr Docs
docs.vultr.com › python › built-in › next
Python next() - Retrieve Next Item | Vultr Docs
September 27, 2024 - The next() function in Python is a built-in utility that retrieves the next item from an iterator. It’s particularly useful when you need to access elements from an iterable object, such as lists or generators, one at a time without using a loop.