Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]


Groups > comp.lang.python > #47364

Re: Idiomatic Python for incrementing pairs

Date 2013-06-07 23:10 -0500
From Tim Chase <python.list@tim.thechases.com>
Subject Re: Idiomatic Python for incrementing pairs
References <20130607213239.3e39a448@bigbox.christie.dr> <CAEk9e3pbF1CUo_k6YGt-40ydVL-zgBrvsLfqhf0zim+L=SZ4yw@mail.gmail.com>
Newsgroups comp.lang.python
Message-ID <mailman.2874.1370664504.3114.python-list@python.org> (permalink)

Show all headers | View raw


On 2013-06-07 23:46, Jason Swails wrote:
> On Fri, Jun 7, 2013 at 10:32 PM, Tim Chase
> >   def calculate(params):
> >     a = b = 0
> >     if some_calculation(params):
> >       a += 1
> >     if other_calculation(params):
> >       b += 1
> >     return (a, b)
> >
> >   alpha = beta = 0
> >   temp_a, temp_b = calculate(...)
> >   alpha += temp_a
> >   beta += temp_b
> >
> > Is there a better way to do this without holding each temporary
> > result before using it to increment?
> 
> alpha = beta = 0
> alpha, beta = (sum(x) for x in zip( (alpha, beta),
> calculate(...) ) )

Yeah, I came up with something similar, but it was so opaque I fell
back to the more readable version I had above.  With only the two
variables to increment in this case, the overhead of duplicating code
doesn't seem as worth it as it might be if there were umpteen
counters being returned as a tuple and umpteen corresponding
variables being updated (at which point, it might make more sense to
switch to another data structure like a dict).  Ah well.  Glad to see
at least I'm not the only one stymied by trying to make it more
pythonic while at least keeping it readable.

-tkc

Back to comp.lang.python | Previous | Next | Find similar | Unroll thread


Thread

Re: Idiomatic Python for incrementing pairs Tim Chase <python.list@tim.thechases.com> - 2013-06-07 23:10 -0500

csiph-web