From f5a2e47ad3bd5ada7d751625c208e65103116f93 Mon Sep 17 00:00:00 2001 From: Raymond Hettinger Date: Wed, 30 Jul 2008 07:37:37 +0000 Subject: [PATCH] Neaten-up the itertools recipes. --- Doc/library/itertools.rst | 10 ++++------ Lib/test/test_itertools.py | 10 ++++------ 2 files changed, 8 insertions(+), 12 deletions(-) diff --git a/Doc/library/itertools.rst b/Doc/library/itertools.rst index 79a69ea0437..71864439a23 100644 --- a/Doc/library/itertools.rst +++ b/Doc/library/itertools.rst @@ -563,12 +563,12 @@ which incur interpreter overhead. return zip(a, b) def grouper(n, iterable, fillvalue=None): - "grouper(3, 'abcdefg', 'x') --> ('a','b','c'), ('d','e','f'), ('g','x','x')" + "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx" args = [iter(iterable)] * n return zip_longest(*args, fillvalue=fillvalue) def roundrobin(*iterables): - "roundrobin('abc', 'd', 'ef') --> 'a', 'd', 'e', 'b', 'f', 'c'" + "roundrobin('ABC', 'D', 'EF') --> A D E B F C" # Recipe credited to George Sakkis pending = len(iterables) nexts = cycle(iter(it).__next__ for it in iterables) @@ -588,10 +588,8 @@ which incur interpreter overhead. yield set(x for m, x in pairs if m&n) def compress(data, selectors): - "compress('abcdef', [1,0,1,0,1,1]) --> a c e f" - decorated = zip(data, selectors) - filtered = filter(operator.itemgetter(1), decorated) - return map(operator.itemgetter(0), filtered) + "compress('ABCDEF', [1,0,1,0,1,1]) --> A C E F" + return (d for d, s in izip(data, selectors) if s) def combinations_with_replacement(iterable, r): "combinations_with_replacement('ABC', 3) --> AA AB AC BB BC CC" diff --git a/Lib/test/test_itertools.py b/Lib/test/test_itertools.py index ee50e2a8c3e..8c482c577b6 100644 --- a/Lib/test/test_itertools.py +++ b/Lib/test/test_itertools.py @@ -1255,13 +1255,13 @@ Samuele ... return zip(a, b) >>> def grouper(n, iterable, fillvalue=None): -... "grouper(3, 'abcdefg', 'x') --> ('a','b','c'), ('d','e','f'), ('g','x','x')" +... "grouper(3, 'ABCDEFG', 'x') --> ABC DEF Gxx" ... args = [iter(iterable)] * n ... kwds = dict(fillvalue=fillvalue) ... return zip_longest(*args, **kwds) >>> def roundrobin(*iterables): -... "roundrobin('abc', 'd', 'ef') --> 'a', 'd', 'e', 'b', 'f', 'c'" +... "roundrobin('ABC', 'D', 'EF') --> A D E B F C" ... # Recipe credited to George Sakkis ... pending = len(iterables) ... nexts = cycle(iter(it).__next__ for it in iterables) @@ -1281,10 +1281,8 @@ Samuele ... yield set(x for m, x in pairs if m&n) >>> def compress(data, selectors): -... "compress('abcdef', [1,0,1,0,1,1]) --> a c e f" -... decorated = zip(data, selectors) -... filtered = filter(operator.itemgetter(1), decorated) -... return map(operator.itemgetter(0), filtered) +... "compress('ABCDEF', [1,0,1,0,1,1]) --> A C E F" +... return (d for d, s in zip(data, selectors) if s) >>> def combinations_with_replacement(iterable, r): ... "combinations_with_replacement('ABC', 3) --> AA AB AC BB BC CC"