summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2018-04-08 21:37:47 (GMT)
committerRaymond Hettinger <rhettinger@users.noreply.github.com>2018-04-08 21:37:47 (GMT)
commit280a767d02c778a33ffb3347ac7cb89b35e41c51 (patch)
treed3f449fa7994f606806c9325f78a92822c4d0cf1
parentb603609e9dd19268b61b52e701cc0ee8e86784c5 (diff)
downloadcpython-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.rst5
-rw-r--r--Lib/test/test_itertools.py8
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')]