Home Backend Development Python Tutorial How to Efficiently Iterate Over Overlapping Pairs (and Triples) in Python Lists?

How to Efficiently Iterate Over Overlapping Pairs (and Triples) in Python Lists?

Dec 22, 2024 am 06:00 AM

How to Efficiently Iterate Over Overlapping Pairs (and Triples) in Python Lists?

How to Iterate Overlapping Value Pairs from a List

When working with lists in Python, it's often necessary to iterate over values in pairs. A common approach is to use a construct such as:

1

2

for current, next in zip(the_list, the_list[1:]):

    # Do something

Copy after login

While this code works, there is a more idiomatic and efficient solution using the pairwise function from the itertools module. Here's a revised Python 3.8 implementation:

1

2

3

4

5

6

7

import itertools

 

def pairwise(iterable):

    "s -> (s0, s1), (s1, s2), (s2, s3), ..."

    a, b = itertools.tee(iterable)

    next(b, None)

    return zip(a, b)

Copy after login

For Python 2, use itertools.izip instead of zip (since zip in Python 2 creates a list instead of a lazy iterator).

The pairwise function works by creating two parallel iterators, a and b, pointing to the same first element. b is then advanced one step ahead using next. The izip function combines the elements from the two iterators to form overlapping pairs.

This approach can also be generalized to handle larger "windows" of values. For example, to iterate over triples of values, use the following function:

1

2

3

4

5

6

7

def threes(iterator):

    "s -> (s0, s1, s2), (s1, s2, s3), (s2, s3, 4), ..."

    a, b, c = itertools.tee(iterator, 3)

    next(b, None)

    next(c, None)

    next(c, None)

    return zip(a, b, c)

Copy after login

Caveat: It's important to note that if one of the iterators advances further than the others due to the use of next, the implementation will hold the consumed elements in memory until all iterators have consumed them.

The above is the detailed content of How to Efficiently Iterate Over Overlapping Pairs (and Triples) in Python Lists?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How Do I Use Beautiful Soup to Parse HTML? How Do I Use Beautiful Soup to Parse HTML? Mar 10, 2025 pm 06:54 PM

How Do I Use Beautiful Soup to Parse HTML?

Image Filtering in Python Image Filtering in Python Mar 03, 2025 am 09:44 AM

Image Filtering in Python

How to Use Python to Find the Zipf Distribution of a Text File How to Use Python to Find the Zipf Distribution of a Text File Mar 05, 2025 am 09:58 AM

How to Use Python to Find the Zipf Distribution of a Text File

How to Work With PDF Documents Using Python How to Work With PDF Documents Using Python Mar 02, 2025 am 09:54 AM

How to Work With PDF Documents Using Python

How to Cache Using Redis in Django Applications How to Cache Using Redis in Django Applications Mar 02, 2025 am 10:10 AM

How to Cache Using Redis in Django Applications

How to Perform Deep Learning with TensorFlow or PyTorch? How to Perform Deep Learning with TensorFlow or PyTorch? Mar 10, 2025 pm 06:52 PM

How to Perform Deep Learning with TensorFlow or PyTorch?

How to Implement Your Own Data Structure in Python How to Implement Your Own Data Structure in Python Mar 03, 2025 am 09:28 AM

How to Implement Your Own Data Structure in Python

Introduction to Parallel and Concurrent Programming in Python Introduction to Parallel and Concurrent Programming in Python Mar 03, 2025 am 10:32 AM

Introduction to Parallel and Concurrent Programming in Python

See all articles