summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiss Islington (bot) <31488909+miss-islington@users.noreply.github.com>2024-03-13 02:40:31 (GMT)
committerGitHub <noreply@github.com>2024-03-13 02:40:31 (GMT)
commit9f38686f6298c656adab7ca09cb235cdef3494e5 (patch)
tree74ec7c7200a4fbfee1e5c040d9b7f865b5844897
parent84c8925e136d22daab4c9172e272137f5b76d9cf (diff)
downloadcpython-9f38686f6298c656adab7ca09cb235cdef3494e5.zip
cpython-9f38686f6298c656adab7ca09cb235cdef3494e5.tar.gz
cpython-9f38686f6298c656adab7ca09cb235cdef3494e5.tar.bz2
[3.12] Minor clarity improvement for the iter_index() recipe. Also add value subsequence tests. (gh-116696) (gh-116698)
-rw-r--r--Doc/library/itertools.rst25
1 files changed, 21 insertions, 4 deletions
diff --git a/Doc/library/itertools.rst b/Doc/library/itertools.rst
index 47c8cf9..53a8246 100644
--- a/Doc/library/itertools.rst
+++ b/Doc/library/itertools.rst
@@ -894,18 +894,19 @@ which incur interpreter overhead.
# iter_index('AABCADEAF', 'A') --> 0 1 4 7
seq_index = getattr(iterable, 'index', None)
if seq_index is None:
- # Slow path for general iterables
+ # Path for general iterables
it = islice(iterable, start, stop)
for i, element in enumerate(it, start):
if element is value or element == value:
yield i
else:
- # Fast path for sequences
+ # Path for sequences with an index() method
stop = len(iterable) if stop is None else stop
- i = start - 1
+ i = start
try:
while True:
- yield (i := seq_index(value, i+1, stop))
+ yield (i := seq_index(value, i, stop))
+ i += 1
except ValueError:
pass
@@ -1400,6 +1401,22 @@ The following recipes have a more mathematical flavor:
>>> ''.join(input_iterator)
'DEAF'
+ >>> # Verify that the target value can be a sequence.
+ >>> seq = [[10, 20], [30, 40], 30, 40, [30, 40], 50]
+ >>> target = [30, 40]
+ >>> list(iter_index(seq, target))
+ [1, 4]
+
+ >>> # Verify faithfulness to type specific index() method behaviors.
+ >>> # For example, bytes and str perform subsequence searches
+ >>> # that do not match the general behavior specified
+ >>> # in collections.abc.Sequence.index().
+ >>> seq = 'abracadabra'
+ >>> target = 'ab'
+ >>> list(iter_index(seq, target))
+ [0, 7]
+
+
>>> list(sieve(30))
[2, 3, 5, 7, 11, 13, 17, 19, 23, 29]
>>> small_primes = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]