Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimanakah Saya Boleh Melaksanakan Lelaran Tetingkap Gelongsor dengan Cekap dalam Python?
Teknik Lelaran Tetingkap Gelongsor
Untuk lelaran tetingkap gelongsor ke atas lelaran, pelaksanaan asas boleh menggunakan penghirisan senarai dan lelaran:
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
Cekap dan Elegan Penyelesaian
Untuk kecekapan dan keanggunan yang lebih tinggi, ungkapan penjana dengan itertools boleh digunakan:
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
Untuk iterable yang lebih mudah seperti senarai atau tupel, pendekatan mudah menggunakan julat dan pengindeksan boleh digunakan:
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])
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Lelaran Tetingkap Gelongsor dengan Cekap dalam Python?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!