diff options
author | Miss Islington (bot) <31488909+miss-islington@users.noreply.github.com> | 2018-04-08 21:37:47 (GMT) |
---|---|---|
committer | Raymond Hettinger <rhettinger@users.noreply.github.com> | 2018-04-08 21:37:47 (GMT) |
commit | 280a767d02c778a33ffb3347ac7cb89b35e41c51 (patch) | |
tree | d3f449fa7994f606806c9325f78a92822c4d0cf1 | |
parent | b603609e9dd19268b61b52e701cc0ee8e86784c5 (diff) | |
download | cpython-280a767d02c778a33ffb3347ac7cb89b35e41c51.zip cpython-280a767d02c778a33ffb3347ac7cb89b35e41c51.tar.gz cpython-280a767d02c778a33ffb3347ac7cb89b35e41c51.tar.bz2 |
Add a prepend() recipe to teach a chain() idiom (GH-6415) (GH-6422)
(cherry picked from commit 9265dd72e5ec1cfa5fcdb5be8ebffe1d9994bd4b)
Co-authored-by: Raymond Hettinger <rhettinger@users.noreply.github.com>
-rw-r--r-- | Doc/library/itertools.rst | 5 | ||||
-rw-r--r-- | Lib/test/test_itertools.py | 8 |
2 files changed, 13 insertions, 0 deletions
diff --git a/Doc/library/itertools.rst b/Doc/library/itertools.rst index 3782f40..3739f50 100644 --- a/Doc/library/itertools.rst +++ b/Doc/library/itertools.rst @@ -688,6 +688,11 @@ which incur interpreter overhead. "Return first n items of the iterable as a list" return list(islice(iterable, n)) + def prepend(value, iterator): + "Prepend a single value in front of an iterator" + # prepend(1, [2, 3, 4]) -> 1 2 3 4 + return chain([value], iterator) + def tabulate(function, start=0): "Return function(0), function(1), ..." return map(function, count(start)) diff --git a/Lib/test/test_itertools.py b/Lib/test/test_itertools.py index 84d11ed..9317951 100644 --- a/Lib/test/test_itertools.py +++ b/Lib/test/test_itertools.py @@ -2165,6 +2165,11 @@ Samuele ... "Return first n items of the iterable as a list" ... return list(islice(iterable, n)) +>>> def prepend(value, iterator): +... "Prepend a single value in front of an iterator" +... # prepend(1, [2, 3, 4]) -> 1 2 3 4 +... return chain([value], iterator) + >>> def enumerate(iterable, start=0): ... return zip(count(start), iterable) @@ -2317,6 +2322,9 @@ perform as purported. >>> take(10, count()) [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] +>>> list(prepend(1, [2, 3, 4])) +[1, 2, 3, 4] + >>> list(enumerate('abc')) [(0, 'a'), (1, 'b'), (2, 'c')] |