python / cpython

The Python programming language
https://www.python.org
Other
63.44k stars 30.38k forks source link

`enumerate` and `filter` documentation should explicitly mention that they accept any iterable #101027

Open JustAnotherArchivist opened 1 year ago

JustAnotherArchivist commented 1 year ago

The documentation of enumerate(iterable, start=0) currently reads:

Return an enumerate object. iterable must be a sequence, an iterator, or some other object which supports iteration. The __next__() method of the iterator returned by enumerate() returns a tuple containing a count (from start which defaults to 0) and the values obtained from iterating over iterable.

This wording dates back to 2002 (commit 38f71973) with minimal changes ('the values obtained' was originally 'the corresponding value obtained', which was slightly more accurate in my opinion). An earlier issue about this paragraph can be found at #66914, though the specific issue at hand, the description of iterable's type, was not really discussed there.

While the parameter name indicates that enumerate accepts any iterable as the first argument, I find it strange that the description explicitly lists

a sequence, an iterator, or some other object which supports iteration

instead of/without actually mentioning 'iterable' and referencing the term's definition in the glossary.

My primary suggestion is to replace (the slightly vague, as it could mean iterable or iterator) 'object which supports iteration' with 'iterable' and a link to the glossary. Additionally, since all iterators are iterables, their mention could also be removed.

Suggestion 1 (with or without a link for 'iterator'):

iterable must be a sequence, an iterator, or some other iterable.

Suggestion 2:

iterable must be a sequence or some other iterable.


filter has a similar situation:

iterable may be either a sequence, a container which supports iteration, or an iterator.

'A container which supports iteration' is quite vague and mildly misleading since other parts of the documentation use the term 'container' for lists and similar types. It also uses 'may' instead of 'must'. I would suggest to use the same wording there as for enumerate.

Linked PRs

ghost commented 1 year ago

Hello! First time contributor here. I would like to take this issue.

JustAnotherArchivist commented 1 year ago

@Dasanant I think this needs some opinion collecting on what's the best wording first. (That's also why I opened it as an issue, not a PR.)

millsks commented 1 year ago

IMHO, I think would lean towards suggestion 2. It mentions sequence so the reader gets the general idea and if they look at the definition of iterable the other types are mentioned with links back to their entry. Keeps it short and concise while providing the reader a way to get to more information.

See also iterator, sequence, and generator.