আপনার যদি কোনও বাহ্যিক প্যাকেজ ব্যবহার করতে আপত্তি না থাকে তবে আপনি 1iteration_utilities.grouper
থেকে ব্যবহার করতে পারেন । এটি সমস্ত পুনরাবৃত্তিকে সমর্থন করে (কেবল ক্রম নয়):iteration_utilties
from iteration_utilities import grouper
seq = list(range(20))
for group in grouper(seq, 4):
print(group)
যা প্রিন্ট করে:
(0, 1, 2, 3)
(4, 5, 6, 7)
(8, 9, 10, 11)
(12, 13, 14, 15)
(16, 17, 18, 19)
দৈর্ঘ্যটি গ্রুপাইজের একাধিক না হলেও এটি শেষ (সম্পূর্ণ অসম্পূর্ণ গ্রুপ) বা কাটা কাটা (অসম্পূর্ণ শেষ গ্রুপটিকে ত্যাগ করে) সর্বশেষকে সমর্থন করে:
from iteration_utilities import grouper
seq = list(range(17))
for group in grouper(seq, 4):
print(group)
# (0, 1, 2, 3)
# (4, 5, 6, 7)
# (8, 9, 10, 11)
# (12, 13, 14, 15)
# (16,)
for group in grouper(seq, 4, fillvalue=None):
print(group)
# (0, 1, 2, 3)
# (4, 5, 6, 7)
# (8, 9, 10, 11)
# (12, 13, 14, 15)
# (16, None, None, None)
for group in grouper(seq, 4, truncate=True):
print(group)
# (0, 1, 2, 3)
# (4, 5, 6, 7)
# (8, 9, 10, 11)
# (12, 13, 14, 15)
benchmarks
আমি উল্লিখিত কয়েকটি পদ্ধতির রান-টাইমের তুলনা করার সিদ্ধান্তও নিয়েছি। এটি বিভিন্ন মাপের তালিকার ভিত্তিতে "10" উপাদানগুলির গ্রুপে লগ-লগ প্লট করে group গুণগত ফলাফলের জন্য: নিম্নের অর্থ দ্রুত:
কমপক্ষে এই বেঞ্চমার্কে সেরা iteration_utilities.grouper
অভিনয় করে। অনুসরণ ক্রেজ এর পদ্ধতির দ্বারা ।
মাপদণ্ডটি তৈরি করা হয়েছিল 1 দিয়ে । এই বেঞ্চমার্কটি চালানোর জন্য ব্যবহৃত কোডটি ছিল:simple_benchmark
import iteration_utilities
import itertools
from itertools import zip_longest
def consume_all(it):
return iteration_utilities.consume(it, None)
import simple_benchmark
b = simple_benchmark.BenchmarkBuilder()
@b.add_function()
def grouper(l, n):
return consume_all(iteration_utilities.grouper(l, n))
def Craz_inner(iterable, n, fillvalue=None):
args = [iter(iterable)] * n
return zip_longest(*args, fillvalue=fillvalue)
@b.add_function()
def Craz(iterable, n, fillvalue=None):
return consume_all(Craz_inner(iterable, n, fillvalue))
def nosklo_inner(seq, size):
return (seq[pos:pos + size] for pos in range(0, len(seq), size))
@b.add_function()
def nosklo(seq, size):
return consume_all(nosklo_inner(seq, size))
def SLott_inner(ints, chunk_size):
for i in range(0, len(ints), chunk_size):
yield ints[i:i+chunk_size]
@b.add_function()
def SLott(ints, chunk_size):
return consume_all(SLott_inner(ints, chunk_size))
def MarkusJarderot1_inner(iterable,size):
it = iter(iterable)
chunk = tuple(itertools.islice(it,size))
while chunk:
yield chunk
chunk = tuple(itertools.islice(it,size))
@b.add_function()
def MarkusJarderot1(iterable,size):
return consume_all(MarkusJarderot1_inner(iterable,size))
def MarkusJarderot2_inner(iterable,size,filler=None):
it = itertools.chain(iterable,itertools.repeat(filler,size-1))
chunk = tuple(itertools.islice(it,size))
while len(chunk) == size:
yield chunk
chunk = tuple(itertools.islice(it,size))
@b.add_function()
def MarkusJarderot2(iterable,size):
return consume_all(MarkusJarderot2_inner(iterable,size))
@b.add_arguments()
def argument_provider():
for exp in range(2, 20):
size = 2**exp
yield size, simple_benchmark.MultiArgument([[0] * size, 10])
r = b.run()
1 অস্বীকৃতি: আমি গ্রন্থাগারগুলির লেখক iteration_utilities
এবং simple_benchmark
।