Does anyone here find the list comprehension syntax awkward?
I like it because it is an expression rather than a series of statements,
but it is a little harder to maintain it seems.
e.g. you could do:
result = []
for element in list:
if element[0:4] == 'blah':
result.append( element.replace ( 'blah', 'moof' ) )
or just:
result = [ element.replace ( 'blah', 'moof' ) for element in list if
element[0:4] == 'blah' ]
The second looks cleaner in some cases, but it is less maintainable. It
tends to promote long lines. It all seems to run together and such. And
often you would need to add another condition or modify it, it seems better
to use the first way even though it has the ugly extra init (and which would
cause more allocs than the list comprehension? because it wouldn't know the
size off the bat?)
I am in favor of short lines like I think Guido said in the style guide. I
like each line to be so simple as to not require any thinking reading it,
e.g.
I prefer:
x = c( d, e )
y = f( g, h )
z = b( x, y )
w = a( z )
to stuff like this:
w = a( b( c( d, e ), f( g, h ) ) )
It is more maintainable, when you need to make a change, just insert a line,
rather than having to decode an expression.
Along the same lines, it seems more maintainable to split things up.
You could do:
result = [
element.replace ( 'blah', 'moof' )
for element in list
if element[0:4] == 'blah' ]
I guess, but that seems awkward to me. Looks too much like a for loop and
an if, and then the value is at the top, which reads funny to me.
(Strangely putting it on one line doesn't read as funny, but it is less
readable.) Maybe I just have to get used to it. Which do you prefer?
Comments?
MB
Jul 18 '05
35 2981
Moosebumps <cr**@crap.crap >
(news:j9******* **********@news svr25.news.prod igy.com) wrote: You could do:
result = [ element.replace ( 'blah', 'moof' ) for element in list if element[0:4] == 'blah' ]
I guess, but that seems awkward to me. Looks too much like a for loop and an if, and then the value is at the top, which reads funny to me. (Strangely putting it on one line doesn't read as funny, but it is less readable.) Maybe I just have to get used to it. Which do you prefer? Comments?
I usually do
result = [
element.replace ( 'blah', 'moof' )
for element in list
if element[0:4] == 'blah'
]
It seems clean and logical enough to me - like e.g. defining big dicts.
On 10 Jul 2004 16:41:16 +0300, Ville Vainio <vi***@spammers .com>
wrote: I think you'll find that you don't need to sacrifice any of your old models or even aesthetic preferences to appreciate LCs.
I'm quite new to python, and I found LC quite simple to understand
and powerful. The only "suprising" part for me was that the looping
variable is not local... I slipped on that a couple of times.
A list comphrension is very "local" in my mind ... I would say that
[x*x for x in xrange(10)] is just a list of perfect squares, but
instead it's not... it's that AND the assignment to x of the value 9.
Andrea What I like about LCs is that they made sense to me before reading the documentation - they just came across as very expressive of what was happening. I use the simplest forms, i.e.
[op(x) for x in y] [x for x in y if z] (as well as some slight variations)
That's true, I tend to use the simplest forms too -- but then that is not as
maintainable.
We all know that things don't always stay so simple. There is always
something you need to add. IMO with that in mind, it is easier to keep
everything consistent, then to try to "sneak in" the LC for the simpler
cases. You would end up flipping back and forth too much when you need to
add a condition, or add an expression. quite a bit, but rarely do I use the more complex forms (e.g. multiple for's) because (1) the meaning doesn't jump right out as quickly (to me) and (2) the more complex they are, the more they seem like a fancy trick rather than the right thing to do.
But most any time you're using map or filter or basically doing:
L = [] for item in L2: L.append(op(ite m))
the LC form is often more desirable because it screams "I'm taking a sequence and using it to create a list" - the intent of the code is very clear. And by extension, if you're using an LC to do something obtuse, you deserve a slap on the wrist (e.g. you write [f() for f in x] and throw away the resulting list).
Now that genexps are coming around, you'll be facing even bigger payoffs. So just keep using them, even if they might not feel as maintanable at the moment. LC's (and genexps even to a bigger extent) are pretty much what defines the "pythonic" way of doing things for me these days.
this is not meant to be picking on you in any way shape or form but my experience has been that any time you find yourself having to "thinking in the language", you are not really solving the right problem and are more likely using a collection of magic tricks to confound and amaze others and possibly insure job security.
That's not what I understood by Ville's comment. I think he just meant that LC's (and genexps) are powerful tools in the Python toolbox, and useful enough that the OP should continue working to become familiar with them. They're not obscure magic tricks but "first class" features of the language.
I've seen many comments on c.l.py to the effect of "LCs seem bad because they can abused", citing bizarre made-up examples with 4 loops and as many if statements. Those *are* magic tricks and should be avoided, but then again any feature can be abused.
if you have models that can be implemented independent of the language and you can express a problem in terms that are natural to the problem, you invariably have a better solution for the people following you as well as the machine.
generalize, don't pythonize.
I'm not so sure. Why program to the lowest common language denominator? I don't suggest going to the extreme to use obscure language quirks just because you can, but it doesn't make sense to avoid using a feature at your disposal because it's unique to a language (or, in this case, a small set of languages).
Half the reason you use one language over another is because of the toolset it gives you. In the case of list comprehensions, they are usually chosen for the very reason that they *do* allow you to express a problem in natural terms.
-Dave
"Ville Vainio" <vi***@spammers .com> wrote in message
news:du******** *****@mozart.cc .tut.fi... >> "Moosebumps " == Moosebumps <cr**@crap.crap > writes: Moosebumps> Does anyone here find the list comprehension syntax
awkward? ...
Moosebumps> I am in favor of short lines like I think Guido said Moosebumps> in the style guide. I like each line to be so simple Moosebumps> as to not require any thinking reading it,
You need to think of the total complexity involved with having several lines. When you see a list comprehension, you know what to expect - transformation and/or filtering applied to a list. Therefore, you can easily read and write out the beast.
Yes, I agree completely! Note that I have no problem with the idea of LC, I
love the idea. I am math person, I am very used to the set syntax:
S = { A(x) | Vx in 2^T }
etc., where V is the "for all", 2^ is powerset, whatever.
I am just wondering about the syntax, that's all. Once you try to come up
with anything a little more complicated than the basic forms, they get to be
too unreadable and unformattable.
I agree it is far superior to use an expression when that is all you need,
and to only use statements when you need them!
MB I usually do result = [ element.replace ( 'blah', 'moof' ) for element in list if element[0:4] == 'blah' ] It seems clean and logical enough to me - like e.g. defining big dicts.
But what if you have multiple for and if's? Seems like you would want to
indent them then.
I think I might just get used to the multiline syntax since LCs are very
useful... it just seems awkward for some reason.
result = [ x for x in blah if f(x) ]
seems more elegant than:
result = [
x
for x in blah
if f(x) ]
but I like to keep things consistent and have maintainability , so then the
second one wins. i.e. the second one "scales better" to more complicated
expressions!
MB
Moosebumps wrote: What I like about LCs is that they made sense to me before reading the documentati on - they just came across as very expressive of what was happening. I use the simplest forms, i.e.
[op(x) for x in y] [x for x in y if z] (as well as some slight variations)
That's true, I tend to use the simplest forms too -- but then that is not as maintainable.
We all know that things don't always stay so simple. There is always something you need to add. IMO with that in mind, it is easier to keep everything consistent, then to try to "sneak in" the LC for the simpler cases. You would end up flipping back and forth too much when you need to add a condition, or add an expression.
I can see the potential for a maintenance problem, but I haven't seen it
actually be a problem in practice.
Perhaps it's due in part to the fact that an LC normally wouldn't "grow"
more complex in isolation - the change would likely be tied to changes
in surrounding code as well - and so maybe the entire code block would
be refactored. Dunno... but compared to the number of times LCs are used
in code, the number of times they are later "unrolled" to the for-loop
form has been too low to worry about.
-Dave
Moosebumps <cr**@crap.crap >
(news:8O******* ***********@new ssvr27.news.pro digy.com) wrote: I usually do result = [ element.replace ( 'blah', 'moof' ) for element in list if element[0:4] == 'blah' ] It seems clean and logical enough to me - like e.g. defining big dicts.
But what if you have multiple for and if's? Seems like you would want to indent them then.
Hm... I never used a complicated enough case :)
I still think I wouldn't indent them - it is clear enough how they corelate.
If anything, I'd do
foo = [
a*b
for a in range(10)
for b in range(10)
for c in ['foo','bar']
if 42==True
]
Can you have multiple ifs at all?
I think I might just get used to the multiline syntax since LCs are very useful... it just seems awkward for some reason.
result = [ x for x in blah if f(x) ]
seems more elegant than:
result = [ x for x in blah if f(x) ]
but I like to keep things consistent and have maintainability , so then the second one wins. i.e. the second one "scales better" to more complicated expressions!
MB
Mitja wrote: Moosebumps <cr**@crap.crap > (news:8O******* ***********@new ssvr27.news.pro digy.com) wrote: I usually do result = [ element.replace ( 'blah', 'moof' ) for element in list if element[0:4] == 'blah' ] It seems clean and logical enough to me - like e.g. defining big dicts.
But what if you have multiple for and if's? Seems like you would want to indent them then.
Hm... I never used a complicated enough case :) I still think I wouldn't indent them - it is clear enough how they corelate. If anything, I'd do foo = [ a*b for a in range(10) for b in range(10) for c in ['foo','bar'] if 42==True ]
Can you have multiple ifs at all?
No, but you can have if (...) and (...) or (...)
Reinhold
--
Wenn eine Linuxdistributi on so wenig brauchbare Software wie Windows
mitbrächte, wäre das bedauerlich. Was bei Windows der Umfang eines
"kompletten Betriebssystems " ist, nennt man bei Linux eine Rescuedisk.
-- David Kastrup in de.comp.os.unix .linux.misc
> > Can you have multiple ifs at all? No, but you can have if (...) and (...) or (...)
Sure you can: result = [x for x in range(10) if x % 2 == 0 if x % 3 == 0] result
[0, 6] result = [ x*y for x in range(10) if x%2 == 0 for y in range(10) if y %
3 == 0] result
[0, 0, 0, 0, 0, 6, 12, 18, 0, 12, 24, 36, 0, 18, 36, 54, 0, 24, 48, 72]
It appears that you can have as many if's and for's as you like.
Just curious -- anyone care to tell me how they would format the above? (or
maybe you wouldn't write it all)
MB
Moosebumps wrote: > Can you have multiple ifs at all?
No, but you can have if (...) and (...) or (...)
Sure you can:
OK, thanks.
Reinhold
--
Wenn eine Linuxdistributi on so wenig brauchbare Software wie Windows
mitbrächte, wäre das bedauerlich. Was bei Windows der Umfang eines
"kompletten Betriebssystems " ist, nennt man bei Linux eine Rescuedisk.
-- David Kastrup in de.comp.os.unix .linux.misc This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics |
by: jsaul |
last post by:
Hi there,
wouldn't it be useful to have a 'while' conditional in addition to
'if' in list comprehensions?
foo =
for i in bar:
if len(i) == 0:
break
foo.append(i)
|
by: Eric |
last post by:
Pythonistas,
I seem at a loss for a List Comprehension syntax that will do what I want.
I have a list of string position spans:
>>> breaks
the first pair representing: someString
|
by: Mahesh Padmanabhan |
last post by:
Hi,
When list comprehension was added to the language, I had a lot of
trouble understanding it but now that I am familiar with it, I am not
sure how I programmed in Python without it.
Now I see that generator expressions have been added to the language
with 2.4 and I question the need for it. I know that it allows for lazy
evaluation which speeds things up for larger lists but why was it
necessary to add it instead of improving list...
|
by: Darren Dale |
last post by:
Hi,
I need to replace the following loop with a list comprehension:
res=
for i in arange(10000):
res=res+i
In practice, res is a complex 2D numarray. For this reason, the regular
output of a list comprehension will not work: constructing a list of every
|
by: Heiko Wundram |
last post by:
Hi all!
The following PEP tries to make the case for a slight unification of for
statement and list comprehension syntax.
Comments appreciated, including on the sample implementation.
===
PEP: xxx
Title: Unification of for-statement and list-comprehension syntax
| |
by: Gregory Guthrie |
last post by:
Sorry for a simple question- but I don't understand how to parse this use of
a list comprehension.
The "or" clauses are odd to me.
It also seems like it is being overly clever (?) in using a lc expression as
a for loop to drive the recursion.
Thanks for any insight!
Gregory
|
by: fdu.xiaojf |
last post by:
Hi all,
I can use list comprehension to create list quickly. So I expected that I
can created tuple quickly with the same syntax. But I found that the
same syntax will get a generator, not a tuple. Here is my example:
In : a = (i for i in range(10))
In : b =
|
by: beginner |
last post by:
Hi All,
If I have a list comprehension:
ab=
c = "ABC"
print c
|
by: Hatem Nassrat |
last post by:
on Wed Jun 13 10:17:24 CEST 2007, Diez B. Roggisch deets at nospam.web.de wrote:
Well I have looked into this and it seems that using the list
comprehension is faster, which is reasonable since generators require
iteration and stop iteration and what not.
|
by: marktang |
last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However, people are often confused as to whether an ONU can Work As a Router. In this blog post, we’ll explore What is ONU, What Is Router, ONU & Router’s main usage, and What is the difference between ONU and Router. Let’s take a closer look !
Part I. Meaning of...
|
by: jinu1996 |
last post by:
In today's digital age, having a compelling online presence is paramount for businesses aiming to thrive in a competitive landscape. At the heart of this digital strategy lies an intricately woven tapestry of website design and digital marketing. It's not merely about having a website; it's about crafting an immersive digital experience that captivates audiences and drives business growth.
The Art of Business Website Design
Your website is...
| |
by: tracyyun |
last post by:
Dear forum friends,
With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each protocol has its own unique characteristics and advantages, but as a user who is planning to build a smart home system, I am a bit confused by the choice of these technologies. I'm particularly interested in Zigbee because I've heard it does some...
|
by: agi2029 |
last post by:
Let's talk about the concept of autonomous AI software engineers and no-code agents. These AIs are designed to manage the entire lifecycle of a software development project—planning, coding, testing, and deployment—without human intervention. Imagine an AI that can take a project description, break it down, write the code, debug it, and then launch it, all on its own....
Now, this would greatly impact the work of software developers. The idea...
|
by: isladogs |
last post by:
The next Access Europe User Group meeting will be on Wednesday 1 May 2024 starting at 18:00 UK time (6PM UTC+1) and finishing by 19:30 (7.30PM).
In this session, we are pleased to welcome a new presenter, Adolph Dupré who will be discussing some powerful techniques for using class modules.
He will explain when you may want to use classes instead of User Defined Types (UDT). For example, to manage the data in unbound forms.
Adolph will...
|
by: TSSRALBI |
last post by:
Hello
I'm a network technician in training and I need your help.
I am currently learning how to create and manage the different types of VPNs and I have a question about LAN-to-LAN VPNs.
The last exercise I practiced was to create a LAN-to-LAN VPN between two Pfsense firewalls, by using IPSEC protocols.
I succeeded, with both firewalls in the same network. But I'm wondering if it's possible to do the same thing, with 2 Pfsense firewalls...
|
by: adsilva |
last post by:
A Windows Forms form does not have the event Unload, like VB6. What one acts like?
|
by: 6302768590 |
last post by:
Hai team
i want code for transfer the data from one system to another through IP address by using C# our system has to for every 5mins then we have to update the data what the data is updated we have to send another system
| |
by: bsmnconsultancy |
last post by:
In today's digital era, a well-designed website is crucial for businesses looking to succeed. Whether you're a small business owner or a large corporation in Toronto, having a strong online presence can significantly impact your brand's success. BSMN Consultancy, a leader in Website Development in Toronto offers valuable insights into creating effective websites that not only look great but also perform exceptionally well. In this comprehensive...
| |