473,396 Members | 1,707 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,396 software developers and data experts.

Why '==' ??

I may be about to get flamed as some heretic against the ancient
way..... but if assignment in conditional statements isn't
possible.... why do we need to use '==' instead of just '=' for if and
while statements ?

It's possible there are places where the interpreter could fail to
understand it, but I haven't found them yet. If there *aren't* any
situations where one could be confused for the other... then it's not
needed and is annoying :-)

The same could equally well be true for the trailing ':' after def, if
etc statements..............
Anyway - not withstanding a visit from the spanish inquisitionI'd be
interested to hear.....(And are the spanish inquisition likely to use
reasoning similar to the sort employed by those who advocate type
declarations and static languages)...

Regards,

Fuzzy
(recent python addict)

http://www.voidspace.org.uk/atlantib...thonutils.html
Jul 18 '05 #1
11 1236
I would assume it's because most people come to Python having programmed
other languages. In most other languages (excepting stuff like
Pascal/Modula-2/etc ...) '=' is used for assignment and '==' for
equality. Thus, in the name of aiding the adoption of Python, it makes
sense to follow this trend.

Fuzzyman wrote:
I may be about to get flamed as some heretic against the ancient
way..... but if assignment in conditional statements isn't
possible.... why do we need to use '==' instead of just '=' for if and
while statements ?

It's possible there are places where the interpreter could fail to
understand it, but I haven't found them yet. If there *aren't* any
situations where one could be confused for the other... then it's not
needed and is annoying :-)

The same could equally well be true for the trailing ':' after def, if
etc statements..............
Anyway - not withstanding a visit from the spanish inquisitionI'd be
interested to hear.....(And are the spanish inquisition likely to use
reasoning similar to the sort employed by those who advocate type
declarations and static languages)...

Regards,

Fuzzy
(recent python addict)

http://www.voidspace.org.uk/atlantib...thonutils.html

Jul 18 '05 #2
> It's possible there are places where the interpreter could fail to
understand it, but I haven't found them yet. If there *aren't* any
situations where one could be confused for the other... then it's not
needed and is annoying :-)
Thats a matter of taste - its easy to spot a comparision, and typing an
additional "=" if you're already over the key - well, python spares me so
wuch typing, I can live with that.
The same could equally well be true for the trailing ':' after def, if
etc statements..............


You are allowed to write

if cond: expression

so the colon makes sense here I believe. And as someone who loathed the
rules for ".", ",", ";" placement in pascal, I can live with the colon even
if a newline appears after the if/def/whatever. Think of the coding
conventions for C or JAVA that forbid the usage of

if(cond)
statement;

and instead insist on {} put around the statements.

Too much freedom in syntax leads to religious wars waged over the style to
use - I'm glad that python lacks that stylewars.

--
Regards,

Diez B. Roggisch
Jul 18 '05 #3

"Fuzzyman" <mi*****@foord.net> wrote in message
news:80*************************@posting.google.co m...
I may be about to get flamed as some heretic against the ancient
way..... but if assignment in conditional statements isn't
possible.... why do we need to use '==' instead of just '=' for if and
while statements ?
I believe the earliest versions of Python did use the single equal
sign for comparisons. I don't know why Guido changed it, but
it might be in order to keep his options open.

John Roth
Regards,

Fuzzy
(recent python addict)

Jul 18 '05 #4
JCM
Fuzzyman <mi*****@foord.net> wrote:
I may be about to get flamed as some heretic against the ancient
way..... but if assignment in conditional statements isn't
possible.... why do we need to use '==' instead of just '=' for if and
while statements ? It's possible there are places where the interpreter could fail to
understand it, but I haven't found them yet. If there *aren't* any
situations where one could be confused for the other... then it's not
needed and is annoying :-)


a = b = c
a = b == c
Jul 18 '05 #5
JCM wrote:
a = b = c
a = b == c


I had no idea you could do that! I was under the impression that
assignment didn't return a value in Python, hence it being impossible to
use one as a conditional.

That explains the use of '==' then - it's necessary to allow the above
construct.
Jul 18 '05 #6
JCM
Vrai Stacey <sp*******************@spam.trap.kbcfp.com> wrote:
JCM wrote:
a = b = c
a = b == c
I had no idea you could do that! I was under the impression that
assignment didn't return a value in Python, hence it being impossible to
use one as a conditional.


Assignment actually doesn't return a value; the multple-assignment
statement assigns a value to the left-hand-sides in a left-to-right
order. Eg:
a = 0
lst = [10, 20, 30, 40]
a = lst[a] = 3
lst

[10, 20, 30, 3]

(You might have expected [3, 20, 30, 40])
Jul 18 '05 #7
JCM wrote:
a = b = c
a = b == c


In fact, it is very funny to see the effect of a=b=c in Basic (or at
least in the Microsoft implementation I know of).

a = 2
b = 3
c = 3
a = b = c
a is assigned 1, which is the result of comparison of b and c. So in
Basic, the first = is like = in Python, and the other are like ==. This
is horrible...
Jul 18 '05 #8
"Fuzzyman" <mi*****@foord.net> wrote in message
news:80*************************@posting.google.co m...
I may be about to get flamed as some heretic against the ancient
way..... but if assignment in conditional statements isn't
possible.... why do we need to use '==' instead of just '=' for if and
while statements ?


One reason is that you can assign multiple variables at the same time:

a = b = c = 0

Would you prefer the first = to be assignment and the others to be
comparison?

(it's certainly possible -- PL/I does it that way -- but would you prefer
it?)
Jul 18 '05 #9
Vrai Stacey wrote:
JCM wrote:
a = b = c
a = b == c


I had no idea you could do that! I was under the impression that
assignment didn't return a value in Python, hence it being impossible
to
use one as a conditional.


Assignment can't, and that isn't one, but the assignment statement is
defined such that you can change assignments together with no problems.

So in

a = b = c

c is the expression evaluated, which is assigned to both a and b,
whereas in

a = b == c

b == c is the exression assigned to a.

--
__ Erik Max Francis && ma*@alcyone.com && http://www.alcyone.com/max/
/ \ San Jose, CA, USA && 37 20 N 121 53 W && &tSftDotIotE
\__/ But you're not going to be there tomorrow. And it's all about
tomorrow. -- Montgomery Brogan
Jul 18 '05 #10
Vrai Stacey <sp*******************@spam.trap.kbcfp.com> wrote:

I would assume it's because most people come to Python having programmed
other languages. In most other languages (excepting stuff like
Pascal/Modula-2/etc ...) '=' is used for assignment and '==' for
equality.


Interesting you would put it that way. I would have guessed that "most"
was not accurate. "In the languages most programmers use", yes, but not
"In most other languages".

C, C++, Java, C#, and Javascript all use = for assignment, == for
compare-equal.

Basic, VBScript, Cobol and SQL use = for both.

Pascal, Modula-X, Algol, Ada, Oberon, and Eiffel use := for assignment, =
for compare-equal.

Fortran uses = for assignment and .EQ. for compare-equal.

APL uses squiggle quad bang hack splat over splat dot splat.

LISP uses -- well, no one really knows what the actual syntax is for LISP.
--
- Tim Roberts, ti**@probo.com
Providenza & Boekelheide, Inc.
Jul 18 '05 #11
On Fri, 02 Apr 2004 17:14:23 -0800,
Tim Roberts <ti**@probo.com> wrote:
LISP uses -- well, no one really knows what the actual syntax is
for LISP.


The syntax is simple: (equality-operator comparand-1 comparand-2)

There are, howver, several equality-operators; some are more equal
than others.

HTH,
Heather

--
Heather Coppersmith
That's not right; that's not even wrong. -- Wolfgang Pauli
Jul 18 '05 #12

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

3
by: William C. White | last post by:
Does anyone know of a way to use PHP /w Authorize.net AIM without using cURL? Our website is hosted on a shared drive and the webhost company doesn't installed additional software (such as cURL)...
2
by: Albert Ahtenberg | last post by:
Hello, I don't know if it is only me but I was sure that header("Location:url") redirects the browser instantly to URL, or at least stops the execution of the code. But appearantely it continues...
3
by: James | last post by:
Hi, I have a form with 2 fields. 'A' 'B' The user completes one of the fields and the form is submitted. On the results page I want to run a query, but this will change subject to which...
0
by: Ollivier Robert | last post by:
Hello, I'm trying to link PHP with Oracle 9.2.0/OCI8 with gcc 3.2.3 on a Solaris9 system. The link succeeds but everytime I try to run php, I get a SEGV from inside the libcnltsh.so library. ...
1
by: Richard Galli | last post by:
I want viewers to compare state laws on a single subject. Imagine a three-column table with a drop-down box on the top. A viewer selects a state from the list, and that state's text fills the...
4
by: Albert Ahtenberg | last post by:
Hello, I have two questions. 1. When the user presses the back button and returns to a form he filled the form is reseted. How do I leave there the values he inserted? 2. When the...
1
by: inderjit S Gabrie | last post by:
Hi all Here is the scenerio ...is it possibly to do this... i am getting valid course dates output on to a web which i have designed ....all is okay so far , look at the following web url ...
2
by: Jack | last post by:
Hi All, What is the PHP equivilent of Oracle bind variables in a SQL statement, e.g. select x from y where z=:parameter Which in asp/jsp would be followed by some statements to bind a value...
3
by: Sandwick | last post by:
I am trying to change the size of a drawing so they are all 3x3. the script below is what i was trying to use to cut it in half ... I get errors. I can display the normal picture but not the...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
by: emmanuelkatto | last post by:
Hi All, I am Emmanuel katto from Uganda. I want to ask what challenges you've faced while migrating a website to cloud. Please let me know. Thanks! Emmanuel
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: Sonnysonu | last post by:
This is the data of csv file 1 2 3 1 2 3 1 2 3 1 2 3 2 3 2 3 3 the lengths should be different i have to store the data by column-wise with in the specific length. suppose the i have to...
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
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,...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
Oralloy
by: Oralloy | last post by:
Hello folks, I am unable to find appropriate documentation on the type promotion of bit-fields when using the generalised comparison operator "<=>". The problem is that using the GNU compilers,...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.