On 22 November 2017 at 14:38, Antoine Pitrou <solipsis at pitrou.net> wrote: > On Wed, 22 Nov 2017 15:03:09 +0200 > Serhiy Storchaka <storchaka at gmail.com> wrote: > > From > > https://stackoverflow.com/questions/45190729/ > differences-between-generator-comprehension-expressions. > > > > g = [(yield i) for i in range(3)] > > > > Syntactically this looks like a list comprehension, and g should be a > > list, right? But actually it is a generator. This code is equivalent to > > the following code: > > > > def _make_list(it): > > result = [] > > for i in it: > > result.append(yield i) > > return result > > g = _make_list(iter(range(3))) > > > > Due to "yield" in the expression _make_list() is not a function > > returning a list, but a generator function returning a generator. > > > > This change in semantic looks unintentional to me. It looks like leaking > > an implementation detail. > > Perhaps we can deprecate the use of "yield" in comprehensions and make > it a syntax error in a couple versions? > > I don't see a reason for writing such code rather than the more > explicit variants. It looks really obscure, regardless of the actual > semantics. > People actually try this (probably simply because they like comprehensions) see two mentioned Stackoverflow questions, plus there are two b.p.o. issues. So this will be a breaking change. Second, recent PEP 530 allowed writing a similar comprehensions with `await`: async def process(funcs): result = [await fun() for fun in funcs] # OK ... Moreover, it has the semantics very similar to the proposed by Serhiy for `yield` (i.e. equivalent to for-loop without name leaking into outer scope). Taking into account that the actual fix is not so hard, I don't think it makes sense to have all the hassles of deprecation period. -- Ivan -------------- next part -------------- An HTML attachment was scrubbed... URL: <http://mail.python.org/pipermail/python-dev/attachments/20171122/bd16cdaa/attachment.html>
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4