ホームページ > バックエンド開発 > Python チュートリアル > Python でスライディング ウィンドウの反復を効率的に実装するにはどうすればよいですか?

Python でスライディング ウィンドウの反復を効率的に実装するにはどうすればよいですか?

DDD
リリース: 2024-12-29 02:37:09
オリジナル
255 人が閲覧しました

How Can I Efficiently Implement Sliding Window Iteration in Python?

スライディング ウィンドウ反復手法

反復可能オブジェクトに対するスライディング ウィンドウ反復の場合、基本的な実装ではリストのスライスと反復を使用できます。

def rolling_window(seq, window_size):
    it = iter(seq)
    win = [it.next() for cnt in range(window_size)]  # First window
    yield win
    for e in it:  # Subsequent windows
        win[:-1] = win[1:]
        win[-1] = e
        yield win
ログイン後にコピー

効率的かつエレガント解決策

効率と優雅さを高めるには、itertools を使用したジェネレーター式を使用できます。

from itertools import islice

def window(seq, n=2):
    "Returns a sliding window (of width n) over data from the iterable"
    "   s -> (s0,s1,...s[n-1]), (s1,s2,...,sn), ..."
    it = iter(seq)
    result = tuple(islice(it, n))
    if len(result) == n:
        yield result
    for elem in it:
        result = result[1:] + (elem,)
        yield result
ログイン後にコピー

リストやタプルのような単純な反復可能オブジェクトの場合は、範囲とインデックス付けを使用した単純なアプローチが可能です。使用可能:

seq = [0, 1, 2, 3, 4, 5]
window_size = 3

for i in range(len(seq) - window_size + 1):
    print(seq[i: i + window_size])
ログイン後にコピー

以上がPython でスライディング ウィンドウの反復を効率的に実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート