Assignment Operators
Add and assign, subtract and assign, multiply and assign, divide and assign, floor divide and assign, exponent and assign, modulo and assign.
to | |||
to and assigns the result to | |||
from and assigns the result to | |||
by and assigns the result to | |||
with and assigns the result to ; the result is always a float | |||
with and assigns the result to ; the result will be dependent on the type of values used | |||
to the power of and assigns the result to | |||
is divided by and assigns the result to |
For demonstration purposes, let’s use a single variable, num . Initially, we set num to 6. We can apply all of these operators to num and update it accordingly.
Assigning the value of 6 to num results in num being 6.
Expression: num = 6
Adding 3 to num and assigning the result back to num would result in 9.
Expression: num += 3
Subtracting 3 from num and assigning the result back to num would result in 6.
Expression: num -= 3
Multiplying num by 3 and assigning the result back to num would result in 18.
Expression: num *= 3
Dividing num by 3 and assigning the result back to num would result in 6.0 (always a float).
Expression: num /= 3
Performing floor division on num by 3 and assigning the result back to num would result in 2.
Expression: num //= 3
Raising num to the power of 3 and assigning the result back to num would result in 216.
Expression: num **= 3
Calculating the remainder when num is divided by 3 and assigning the result back to num would result in 2.
Expression: num %= 3
We can effectively put this into Python code, and you can experiment with the code yourself! Click the “Run” button to see the output.
The above code is useful when we want to update the same number. We can also use two different numbers and use the assignment operators to apply them on two different values.
The Walrus Operator: Python 3.8 Assignment Expressions
Table of Contents
Hello, Walrus!
Implementation, lists and dictionaries, list comprehensions, while loops, witnesses and counterexamples, walrus operator syntax, walrus operator pitfalls.
Watch Now This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Python Assignment Expressions and Using the Walrus Operator
Each new version of Python adds new features to the language. For Python 3.8, the biggest change is the addition of assignment expressions . Specifically, the := operator gives you a new syntax for assigning variables in the middle of expressions. This operator is colloquially known as the walrus operator .
This tutorial is an in-depth introduction to the walrus operator. You will learn some of the motivations for the syntax update and explore some examples where assignment expressions can be useful.
In this tutorial, you’ll learn how to:
- Identify the walrus operator and understand its meaning
- Understand use cases for the walrus operator
- Avoid repetitive code by using the walrus operator
- Convert between code using the walrus operator and code using other assignment methods
- Understand the impacts on backward compatibility when using the walrus operator
- Use appropriate style in your assignment expressions
Note that all walrus operator examples in this tutorial require Python 3.8 or later to work.
Free Download: Get a sample chapter from Python Tricks: The Book that shows you Python’s best practices with simple examples you can apply instantly to write more beautiful + Pythonic code.
Walrus Operator Fundamentals
Let’s start with some different terms that programmers use to refer to this new syntax. You’ve already seen a few in this tutorial.
The := operator is officially known as the assignment expression operator . During early discussions, it was dubbed the walrus operator because the := syntax resembles the eyes and tusks of a sideways walrus . You may also see the := operator referred to as the colon equals operator . Yet another term used for assignment expressions is named expressions .
To get a first impression of what assignment expressions are all about, start your REPL and play around with the following code:
Line 1 shows a traditional assignment statement where the value False is assigned to walrus . Next, on line 5, you use an assignment expression to assign the value True to walrus . After both lines 1 and 5, you can refer to the assigned values by using the variable name walrus .
You might be wondering why you’re using parentheses on line 5, and you’ll learn why the parentheses are needed later on in this tutorial .
Note: A statement in Python is a unit of code. An expression is a special statement that can be evaluated to some value.
For example, 1 + 2 is an expression that evaluates to the value 3 , while number = 1 + 2 is an assignment statement that doesn’t evaluate to a value. Although running the statement number = 1 + 2 doesn’t evaluate to 3 , it does assign the value 3 to number .
In Python, you often see simple statements like return statements and import statements , as well as compound statements like if statements and function definitions . These are all statements, not expressions.
There’s a subtle—but important—difference between the two types of assignments seen earlier with the walrus variable. An assignment expression returns the value, while a traditional assignment doesn’t. You can see this in action when the REPL doesn’t print any value after walrus = False on line 1, while it prints out True after the assignment expression on line 5.
You can see another important aspect about walrus operators in this example. Though it might look new, the := operator does not do anything that isn’t possible without it. It only makes certain constructs more convenient and can sometimes communicate the intent of your code more clearly.
Note: You need at least Python 3.8 to try out the examples in this tutorial. If you don’t already have Python 3.8 installed and you have Docker available, a quick way to start working with Python 3.8 is to run one of the official Docker images :
This will download and run the latest stable version of Python 3.8. For more information, see Run Python Versions in Docker: How to Try the Latest Python Release .
Now you have a basic idea of what the := operator is and what it can do. It’s an operator used in assignment expressions, which can return the value being assigned, unlike traditional assignment statements. To get deeper and really learn about the walrus operator, continue reading to see where you should and shouldn’t use it.
Like most new features in Python, assignment expressions were introduced through a Python Enhancement Proposal (PEP). PEP 572 describes the motivation for introducing the walrus operator, the details of the syntax, as well as examples where the := operator can be used to improve your code.
This PEP was originally written by Chris Angelico in February 2018. Following some heated discussion, PEP 572 was accepted by Guido van Rossum in July 2018. Since then, Guido announced that he was stepping down from his role as benevolent dictator for life (BDFL) . Starting in early 2019, Python has been governed by an elected steering council instead.
The walrus operator was implemented by Emily Morehouse , and made available in the first alpha release of Python 3.8.
In many languages, including C and its derivatives, assignment statements function as expressions. This can be both very powerful and also a source of confusing bugs. For example, the following code is valid C but doesn’t execute as intended:
Here, if (x = y) will evaluate to true and the code snippet will print out x and y are equal (x = 8, y = 8) . Is this the result you were expecting? You were trying to compare x and y . How did the value of x change from 3 to 8 ?
The problem is that you’re using the assignment operator ( = ) instead of the equality comparison operator ( == ). In C, x = y is an expression that evaluates to the value of y . In this example, x = y is evaluated as 8 , which is considered truthy in the context of the if statement.
Take a look at a corresponding example in Python. This code raises a SyntaxError :
Unlike the C example, this Python code gives you an explicit error instead of a bug.
The distinction between assignment statements and assignment expressions in Python is useful in order to avoid these kinds of hard-to-find bugs. PEP 572 argues that Python is better suited to having different syntax for assignment statements and expressions instead of turning the existing assignment statements into expressions.
One design principle underpinning the walrus operator is that there are no identical code contexts where both an assignment statement using the = operator and an assignment expression using the := operator would be valid. For example, you can’t do a plain assignment with the walrus operator:
In many cases, you can add parentheses ( () ) around the assignment expression to make it valid Python:
Writing a traditional assignment statement with = is not allowed inside such parentheses. This helps you catch potential bugs.
Later on in this tutorial , you’ll learn more about situations where the walrus operator is not allowed, but first you’ll learn about the situations where you might want to use them.
Walrus Operator Use Cases
In this section, you’ll see several examples where the walrus operator can simplify your code. A general theme in all these examples is that you’ll avoid different kinds of repetition:
- Repeated function calls can make your code slower than necessary.
- Repeated statements can make your code hard to maintain.
- Repeated calls that exhaust iterators can make your code overly complex.
You’ll see how the walrus operator can help in each of these situations.
Arguably one of the best use cases for the walrus operator is when debugging complex expressions. Say that you want to find the distance between two locations along the earth’s surface. One way to do this is to use the haversine formula :
ϕ represents the latitude and λ represents the longitude of each location. To demonstrate this formula, you can calculate the distance between Oslo (59.9°N 10.8°E) and Vancouver (49.3°N 123.1°W) as follows:
As you can see, the distance from Oslo to Vancouver is just under 7200 kilometers.
Note: Python source code is typically written using UTF-8 Unicode . This allows you to use Greek letters like ϕ and λ in your code, which may be useful when translating mathematical formulas. Wikipedia shows some alternatives for using Unicode on your system.
While UTF-8 is supported (in string literals, for instance), Python’s variable names use a more limited character set . For example, you can’t use emojis while naming your variables. That is a good restriction !
Now, say that you need to double-check your implementation and want to see how much the haversine terms contribute to the final result. You could copy and paste the term from your main code to evaluate it separately. However, you could also use the := operator to give a name to the subexpression you’re interested in:
The advantage of using the walrus operator here is that you calculate the value of the full expression and keep track of the value of ϕ_hav at the same time. This allows you to confirm that you did not introduce any errors while debugging.
Lists are powerful data structures in Python that often represent a series of related attributes. Similarly, dictionaries are used all over Python and are great for structuring information.
Sometimes when setting up these data structures, you end up performing the same operation several times. As a first example, calculate some basic descriptive statistics of a list of numbers and store them in a dictionary:
Note that both the sum and the length of the numbers list are calculated twice. The consequences are not too bad in this simple example, but if the list was larger or the calculations were more complicated, you might want to optimize the code. To do this, you can first move the function calls out of the dictionary definition:
The variables num_length and num_sum are only used to optimize the calculations inside the dictionary. By using the walrus operator, this role can be made more clear:
num_length and num_sum are now defined inside the definition of description . This is a clear hint to anybody reading this code that these variables are just used to optimize these calculations and aren’t used again later.
Note: The scope of the num_length and num_sum variables is the same in the example with the walrus operator and in the example without. This means that in both examples, the variables are available after the definition of description .
Even though both examples are very similar functionally, a benefit of using the assignment expressions is that the := operator communicates the intent of these variables as throwaway optimizations.
In the next example, you’ll work with a bare-bones implementation of the wc utility for counting lines, words, and characters in a text file:
This script can read one or several text files and report how many lines, words, and characters each of them contains. Here’s a breakdown of what’s happening in the code:
- Line 6 loops over each filename provided by the user. sys.argv is a list containing each argument given on the command line, starting with the name of your script. For more information about sys.argv , you can check out Python Command Line Arguments .
- Line 7 translates each filename string to a pathlib.Path object . Storing a filename in a Path object allows you to conveniently read the text file in the next lines.
- Lines 8 to 12 construct a tuple of counts to represent the number of lines, words, and characters in one text file.
- Line 9 reads a text file and calculates the number of lines by counting newlines.
- Line 10 reads a text file and calculates the number of words by splitting on whitespace.
- Line 11 reads a text file and calculates the number of characters by finding the length of the string.
- Line 13 prints all three counts together with the filename to the console. The *counts syntax unpacks the counts tuple. In this case, the print() statement is equivalent to print(counts[0], counts[1], counts[2], path) .
To see wc.py in action, you can use the script on itself as follows:
In other words, the wc.py file consists of 13 lines, 34 words, and 316 characters.
If you look closely at this implementation, you’ll notice that it’s far from optimal. In particular, the call to path.read_text() is repeated three times. That means that each text file is read three times. You can use the walrus operator to avoid the repetition:
The contents of the file are assigned to text , which is reused in the next two calculations. The program still functions the same:
As in the earlier examples, an alternative approach is to define text before the definition of counts :
While this is one line longer than the previous implementation, it probably provides the best balance between readability and efficiency. The := assignment expression operator isn’t always the most readable solution even when it makes your code more concise.
List comprehensions are great for constructing and filtering lists. They clearly state the intent of the code and will usually run quite fast.
There’s one list comprehension use case where the walrus operator can be particularly useful. Say that you want to apply some computationally expensive function, slow() , to the elements in your list and filter on the resulting values. You could do something like the following:
Here, you filter the numbers list and leave the positive results from applying slow() . The problem with this code is that this expensive function is called twice.
A very common solution for this type of situation is rewriting your code to use an explicit for loop:
This will only call slow() once. Unfortunately, the code is now more verbose, and the intent of the code is harder to understand. The list comprehension had clearly signaled that you were creating a new list, while this is more hidden in the explicit for loop since several lines of code separate the list creation and the use of .append() . Additionally, the list comprehension runs faster than the repeated calls to .append() .
You can code some other solutions by using a filter() expression or a kind of double list comprehension:
The good news is that there’s only one call to slow() for each number. The bad news is that the code’s readability has suffered in both expressions.
Figuring out what’s actually happening in the double list comprehension takes a fair amount of head-scratching. Essentially, the second for statement is used only to give the name value to the return value of slow(num) . Fortunately, that sounds like something that can instead be performed with an assignment expression!
You can rewrite the list comprehension using the walrus operator as follows:
Note that the parentheses around value := slow(num) are required. This version is effective, readable, and communicates the intent of the code well.
Note: You need to add the assignment expression on the if clause of the list comprehension. If you try to define value with the other call to slow() , then it will not work:
This will raise a NameError because the if clause is evaluated before the expression at the beginning of the comprehension.
Let’s look at a slightly more involved and practical example. Say that you want to use the Real Python feed to find the titles of the last episodes of the Real Python Podcast .
You can use the Real Python Feed Reader to download information about the latest Real Python publications. In order to find the podcast episode titles, you’ll use the third-party Parse package. Start by installing both into your virtual environment :
You can now read the latest titles published by Real Python :
Podcast titles start with "The Real Python Podcast" , so here you can create a pattern that Parse can use to identify them:
Compiling the pattern beforehand speeds up later comparisons, especially when you want to match the same pattern over and over. You can check if a string matches your pattern using either pattern.parse() or pattern.search() :
Note that Parse is able to pick out the podcast episode number and the episode name. The episode number is converted to an integer data type because you used the :d format specifier .
Let’s get back to the task at hand. In order to list all the recent podcast titles, you need to check whether each string matches your pattern and then parse out the episode title. A first attempt may look something like this:
Though it works, you might notice the same problem you saw earlier. You’re parsing each title twice because you filter out titles that match your pattern and then use that same pattern to pick out the episode title.
Like you did earlier, you can avoid the double work by rewriting the list comprehension using either an explicit for loop or a double list comprehension. Using the walrus operator, however, is even more straightforward:
Assignment expressions work well to simplify these kinds of list comprehensions. They help you keep your code readable while you avoid doing a potentially expensive operation twice.
Note: The Real Python Podcast has its own separate RSS feed , which you should use if you want to play around with information only about the podcast. You can get all the episode titles with the following code:
See The Real Python Podcast for options to listen to it using your podcast player.
In this section, you’ve focused on examples where list comprehensions can be rewritten using the walrus operator. The same principles also apply if you see that you need to repeat an operation in a dictionary comprehension , a set comprehension , or a generator expression .
The following example uses a generator expression to calculate the average length of episode titles that are over 50 characters long:
The generator expression uses an assignment expression to avoid calculating the length of each episode title twice.
Python has two different loop constructs: for loops and while loops . You typically use a for loop when you need to iterate over a known sequence of elements. A while loop, on the other hand, is used when you don’t know beforehand how many times you’ll need to loop.
In while loops, you need to define and check the ending condition at the top of the loop. This sometimes leads to some awkward code when you need to do some setup before performing the check. Here’s a snippet from a multiple-choice quiz program that asks the user to answer a question with one of several valid answers:
This works but has an unfortunate repetition of identical input() lines. It’s necessary to get at least one answer from the user before checking whether it’s valid or not. You then have a second call to input() inside the while loop to ask for a second answer in case the original user_answer wasn’t valid.
If you want to make your code more maintainable, it’s quite common to rewrite this kind of logic with a while True loop. Instead of making the check part of the main while statement, the check is performed later in the loop together with an explicit break :
This has the advantage of avoiding the repetition. However, the actual check is now harder to spot.
Assignment expressions can often be used to simplify these kinds of loops. In this example, you can now put the check back together with while where it makes more sense:
The while statement is a bit denser, but the code now communicates the intent more clearly without repeated lines or seemingly infinite loops.
You can expand the box below to see the full code of the multiple-choice quiz program and try a couple of questions about the walrus operator yourself.
Full source code of multiple-choice quiz program Show/Hide
This script runs a multiple-choice quiz. You’ll be asked each of the questions in order, but the order of answers will be shuffled each time:
Note that the first answer is assumed to be the correct one. You can add more questions to the quiz yourself. Feel free to share your questions with the community in the comments section below the tutorial!
You can often simplify while loops by using assignment expressions. The original PEP shows an example from the standard library that makes the same point.
In the examples you’ve seen so far, the := assignment expression operator does essentially the same job as the = assignment operator in your old code. You’ve seen how to simplify code, and now you’ll learn about a different type of use case that’s made possible by this new operator.
In this section, you’ll learn how you can find witnesses when calling any() by using a clever trick that isn’t possible without using the walrus operator. A witness, in this context, is an element that satisfies the check and causes any() to return True .
By applying similar logic, you’ll also learn how you can find counterexamples when working with all() . A counterexample, in this context, is an element that doesn’t satisfy the check and causes all() to return False .
In order to have some data to work with, define the following list of city names:
You can use any() and all() to answer questions about your data:
In each of these cases, any() and all() give you plain True or False answers. What if you’re also interested in seeing an example or a counterexample of the city names? It could be nice to see what’s causing your True or False result:
Does any city name start with "H" ?
Yes, because "Houston" starts with "H" .
Do all city names start with "H" ?
No, because "Oslo" doesn’t start with "H" .
In other words, you want a witness or a counterexample to justify the answer.
Capturing a witness to an any() expression has not been intuitive in earlier versions of Python. If you were calling any() on a list and then realized you also wanted a witness, you’d typically need to rewrite your code:
Here, you first capture all city names that start with "H" . Then, if there’s at least one such city name, you print out the first city name starting with "H" . Note that here you’re actually not using any() even though you’re doing a similar operation with the list comprehension.
By using the := operator, you can find witnesses directly in your any() expressions:
You can capture a witness inside the any() expression. The reason this works is a bit subtle and relies on any() and all() using short-circuit evaluation : they only check as many items as necessary to determine the result.
Note: If you want to check whether all city names start with the letter "H" , then you can look for a counterexample by replacing any() with all() and updating the print() functions to report the first item that doesn’t pass the check.
You can see what’s happening more clearly by wrapping .startswith("H") in a function that also prints out which item is being checked:
Note that any() doesn’t actually check all items in cities . It only checks items until it finds one that satisfies the condition. Combining the := operator and any() works by iteratively assigning each item that is being checked to witness . However, only the last such item survives and shows which item was last checked by any() .
Even when any() returns False , a witness is found:
However, in this case, witness doesn’t give any insight. 'Holguín' doesn’t contain ten or more characters. The witness only shows which item happened to be evaluated last.
One of the main reasons assignments were not expressions in Python from the beginning is that the visual likeness of the assignment operator ( = ) and the equality comparison operator ( == ) could potentially lead to bugs. When introducing assignment expressions, a lot of thought was put into how to avoid similar bugs with the walrus operator. As mentioned earlier , one important feature is that the := operator is never allowed as a direct replacement for the = operator, and vice versa.
As you saw at the beginning of this tutorial, you can’t use a plain assignment expression to assign a value:
It’s syntactically legal to use an assignment expression to only assign a value, but only if you add parentheses:
Even though it’s possible, however, this really is a prime example of where you should stay away from the walrus operator and use a traditional assignment statement instead.
PEP 572 shows several other examples where the := operator is either illegal or discouraged. The following examples all raise a SyntaxError :
In all these cases, you’re better served using = instead. The next examples are similar and are all legal code. However, the walrus operator doesn’t improve your code in any of these cases:
None of these examples make your code more readable. You should instead do the extra assignment separately by using a traditional assignment statement. See PEP 572 for more details about the reasoning.
There’s one use case where the := character sequence is already valid Python. In f-strings , a colon ( : ) is used to separate values from their format specification . For example:
The := in this case does look like a walrus operator, but the effect is quite different. To interpret x:=8 inside the f-string, the expression is broken into three parts: x , : , and =8 .
Here, x is the value, : acts as a separator, and =8 is a format specification. According to Python’s Format Specification Mini-Language , in this context = specifies an alignment option. In this case, the value is padded with spaces in a field of width 8 .
To use assignment expressions inside f-strings, you need to add parentheses:
This updates the value of x as expected. However, you’re probably better off using traditional assignments outside of your f-strings instead.
Let’s look at some other situations where assignment expressions are illegal:
Attribute and item assignment: You can only assign to simple names, not dotted or indexed names:
This fails with a descriptive error message. There’s no straightforward workaround.
Iterable unpacking: You can’t unpack when using the walrus operator:
If you add parentheses around the whole expression, it will be interpreted as a 3-tuple with the three elements lat , 59.9 , and 10.8 .
Augmented assignment: You can’t use the walrus operator combined with augmented assignment operators like += . This raises a SyntaxError :
The easiest workaround would be to do the augmentation explicitly. You could, for example, do (count := count + 1) . PEP 577 originally described how to add augmented assignment expressions to Python, but the proposal was withdrawn.
When you’re using the walrus operator, it will behave similarly to traditional assignment statements in many respects:
The scope of the assignment target is the same as for assignments. It will follow the LEGB rule . Typically, the assignment will happen in the local scope, but if the target name is already declared global or nonlocal , that is honored.
The precedence of the walrus operator can cause some confusion. It binds less tightly than all other operators except the comma, so you might need parentheses to delimit the expression that is assigned. As an example, note what happens when you don’t use parentheses:
square is bound to the whole expression number ** 2 > 5 . In other words, square gets the value True and not the value of number ** 2 , which was the intention. In this case, you can delimit the expression with parentheses:
The parentheses make the if statement both clearer and actually correct.
There’s one final gotcha. When assigning a tuple using the walrus operator, you always need to use parentheses around the tuple. Compare the following assignments:
Note that in the second example, walrus takes the value 3.8 and not the whole tuple 3.8, True . That’s because the := operator binds more tightly than the comma. This may seem a bit annoying. However, if the := operator bound less tightly than the comma, it would not be possible to use the walrus operator in function calls with more than one argument.
The style recommendations for the walrus operator are mostly the same as for the = operator used for assignment. First, always add spaces around the := operator in your code. Second, use parentheses around the expression as necessary, but avoid adding extra parentheses that are not needed.
The general design of assignment expressions is to make them easy to use when they are helpful but to avoid overusing them when they might clutter up your code.
The walrus operator is a new syntax that is only available in Python 3.8 and later. This means that any code you write that uses the := syntax will only work on the most recent versions of Python.
If you need to support older versions of Python, you can’t ship code that uses assignment expressions. There are some projects, like walrus , that can automatically translate walrus operators into code that is compatible with older versions of Python. This allows you to take advantage of assignment expressions when writing your code and still distribute code that is compatible with more Python versions.
Experience with the walrus operator indicates that := will not revolutionize Python. Instead, using assignment expressions where they are useful can help you make several small improvements to your code that could benefit your work overall.
There are many times it’s possible for you to use the walrus operator, but where it won’t necessarily improve the readability or efficiency of your code. In those cases, you’re better off writing your code in a more traditional manner.
You now know how the new walrus operator works and how you can use it in your own code. By using the := syntax, you can avoid different kinds of repetition in your code and make your code both more efficient and easier to read and maintain. At the same time, you shouldn’t use assignment expressions everywhere. They will only help you in some use cases.
In this tutorial, you learned how to:
To learn more about the details of assignment expressions, see PEP 572 . You can also check out the PyCon 2019 talk PEP 572: The Walrus Operator , where Dustin Ingram gives an overview of both the walrus operator and the discussion around the new PEP.
🐍 Python Tricks 💌
Get a short & sweet Python Trick delivered to your inbox every couple of days. No spam ever. Unsubscribe any time. Curated by the Real Python team.
About Geir Arne Hjelle
Geir Arne is an avid Pythonista and a member of the Real Python tutorial team.
Each tutorial at Real Python is created by a team of developers so that it meets our high quality standards. The team members who worked on this tutorial are:
Master Real-World Python Skills With Unlimited Access to Real Python
Join us and get access to thousands of tutorials, hands-on video courses, and a community of expert Pythonistas:
Join us and get access to thousands of tutorials, hands-on video courses, and a community of expert Pythonistas:
What Do You Think?
What’s your #1 takeaway or favorite thing you learned? How are you going to put your newfound skills to use? Leave a comment below and let us know.
Commenting Tips: The most useful comments are those written with the goal of learning from or helping out other students. Get tips for asking good questions and get answers to common questions in our support portal . Looking for a real-time conversation? Visit the Real Python Community Chat or join the next “Office Hours” Live Q&A Session . Happy Pythoning!
Keep Learning
Related Topics: intermediate best-practices
Recommended Video Course: Python Assignment Expressions and Using the Walrus Operator
Keep reading Real Python by creating a free account or signing in:
Already have an account? Sign-In
Almost there! Complete this form and click the button below to gain instant access:
"Python Tricks: The Book" – Free Sample Chapter (PDF)
🔒 No spam. We take your privacy seriously.
Python Tutorial
File handling, python modules, python numpy, python pandas, python matplotlib, python scipy, machine learning, python mysql, python mongodb, python reference, module reference, python how to, python examples, python operators.
Operators are used to perform operations on variables and values.
In the example below, we use the + operator to add together two values:
Python divides the operators in the following groups:
- Arithmetic operators
- Assignment operators
- Comparison operators
- Logical operators
- Identity operators
- Membership operators
- Bitwise operators
Python Arithmetic Operators
Arithmetic operators are used with numeric values to perform common mathematical operations:
Operator | Name | Example | Try it |
---|---|---|---|
+ | Addition | x + y | |
- | Subtraction | x - y | |
* | Multiplication | x * y | |
/ | Division | x / y | |
% | Modulus | x % y | |
** | Exponentiation | x ** y | |
// | Floor division | x // y |
Python Assignment Operators
Assignment operators are used to assign values to variables:
Operator | Example | Same As | Try it |
---|---|---|---|
= | x = 5 | x = 5 | |
+= | x += 3 | x = x + 3 | |
-= | x -= 3 | x = x - 3 | |
*= | x *= 3 | x = x * 3 | |
/= | x /= 3 | x = x / 3 | |
%= | x %= 3 | x = x % 3 | |
//= | x //= 3 | x = x // 3 | |
**= | x **= 3 | x = x ** 3 | |
&= | x &= 3 | x = x & 3 | |
|= | x |= 3 | x = x | 3 | |
^= | x ^= 3 | x = x ^ 3 | |
>>= | x >>= 3 | x = x >> 3 | |
<<= | x <<= 3 | x = x << 3 | |
:= | print(x := 3) | x = 3 print(x) |
Advertisement
Python Comparison Operators
Comparison operators are used to compare two values:
Operator | Name | Example | Try it |
---|---|---|---|
== | Equal | x == y | |
!= | Not equal | x != y | |
> | Greater than | x > y | |
< | Less than | x < y | |
>= | Greater than or equal to | x >= y | |
<= | Less than or equal to | x <= y |
Python Logical Operators
Logical operators are used to combine conditional statements:
Operator | Description | Example | Try it |
---|---|---|---|
and | Returns True if both statements are true | x < 5 and x < 10 | |
or | Returns True if one of the statements is true | x < 5 or x < 4 | |
not | Reverse the result, returns False if the result is true | not(x < 5 and x < 10) |
Python Identity Operators
Identity operators are used to compare the objects, not if they are equal, but if they are actually the same object, with the same memory location:
Operator | Description | Example | Try it |
---|---|---|---|
is | Returns True if both variables are the same object | x is y | |
is not | Returns True if both variables are not the same object | x is not y |
Python Membership Operators
Membership operators are used to test if a sequence is presented in an object:
Operator | Description | Example | Try it |
---|---|---|---|
in | Returns True if a sequence with the specified value is present in the object | x in y | |
not in | Returns True if a sequence with the specified value is not present in the object | x not in y |
Python Bitwise Operators
Bitwise operators are used to compare (binary) numbers:
Operator | Name | Description | Example | Try it |
---|---|---|---|---|
& | AND | Sets each bit to 1 if both bits are 1 | x & y | |
| | OR | Sets each bit to 1 if one of two bits is 1 | x | y | |
^ | XOR | Sets each bit to 1 if only one of two bits is 1 | x ^ y | |
~ | NOT | Inverts all the bits | ~x | |
<< | Zero fill left shift | Shift left by pushing zeros in from the right and let the leftmost bits fall off | x << 2 | |
>> | Signed right shift | Shift right by pushing copies of the leftmost bit in from the left, and let the rightmost bits fall off | x >> 2 |
Operator Precedence
Operator precedence describes the order in which operations are performed.
Parentheses has the highest precedence, meaning that expressions inside parentheses must be evaluated first:
Multiplication * has higher precedence than addition + , and therefor multiplications are evaluated before additions:
The precedence order is described in the table below, starting with the highest precedence at the top:
Operator | Description | Try it |
---|---|---|
Parentheses | ||
Exponentiation | ||
Unary plus, unary minus, and bitwise NOT | ||
Multiplication, division, floor division, and modulus | ||
Addition and subtraction | ||
Bitwise left and right shifts | ||
Bitwise AND | ||
Bitwise XOR | ||
Bitwise OR | ||
Comparisons, identity, and membership operators | ||
Logical NOT | ||
AND | ||
OR |
If two operators have the same precedence, the expression is evaluated from left to right.
Addition + and subtraction - has the same precedence, and therefor we evaluate the expression from left to right:
Test Yourself With Exercises
Multiply 10 with 5 , and print the result.
Start the Exercise
COLOR PICKER
Contact Sales
If you want to use W3Schools services as an educational institution, team or enterprise, send us an e-mail: [email protected]
Report Error
If you want to report an error, or if you want to make a suggestion, send us an e-mail: [email protected]
Top Tutorials
Top references, top examples, get certified.
01 Career Opportunities
- 10 Python Developer Skills you must know in 2024
- How to Become a Python Full Stack Developer [Step-by-Step]
- Python Career Guide: Is it worth learning in 2024?
- Python Developer Roadmap: How to become a Python Developer?
- Top 50+ Python Interview Questions and Answers
- Python Developer Salary
02 Beginner
- Difference between For Loop and While Loop in Python
- Bitwise Operators in Python
- Logical Operators Python
- Comparison Operators Python
- Understanding Python While Loop with Examples
- Program to Check Leap Year in Python
- The enumerate() Function in Python
- How to Run a Python Script- A Step by Step Guide
- Python Program to Check Prime Number
- Lambda() Function in Python
- Fibonacci Series in Python
- Data Structures in Python - Types and Examples (A Complete Guide)
- Calculation of Armstrong Number in Python
- The map() Function in Python
- Factorial Calculator in Python
- Python For Loop
- Python Membership Operators: Types of Membership Operators
Assignment Operators in Python
- Arithmetic Operators in Python
- Addition of Two Numbers in Python
- What is a Python Interpreter?
- Python Features: A Comprehensive Guide for Beginners
- Understanding Constructors in Python
- List of Python Keywords (With Examples)
- Introduction to the python language
- What is Python Language? Overview of the Python Language
- Python Basic Syntax: First Python Program
- Comments in Python: An Overview
- What are Python Variables - Types of Variables in Python Language
- Data Types in Python - 8 Data Types in Python With Examples
- What are Operators in Python - Types of Operators in Python ( With Examples )
- Decision Making Statements: If, If..else, Nested If..else and if-elif-else Ladder
- 10 Reasons Python is a Great First Language to Learn
- Types of Loops in Python - For, While Loop
- Tuples in Python with Examples - A Beginner Guide
- Python Functions: A Complete Guide
03 Intermediate
- Python Classes and Objects with Examples
- How to Use List Comprehension in Python
- OOPs Concepts in Python
- What are Strings in Python? Learn to Implement Them.
- Python Lists: List Methods and Operations
- Python Dictionaries (With Examples) : A Comprehensive Tutorial
- Modules in Python
- Exception Handling in Python: Try and Except Statement
04 Training Programs
- Java Programming Course
- MERN: Full-Stack Web Developer Certification Training
- Data Structures and Algorithms Training
- Assignment Operators In P..
What is an Assignment Operator in Python?
Assignment Operators in Python are used to assign values to the variables. "=" is the fundamental Python assignment operator. They require two operands to operate upon. The left side operand is called a variable, and the right side operand is the value. The value on the right side of the "=" is assigned to the variable on the left side of "=". The associativity is from right to left.
1. Augmented Arithmetic Assignment Operators in Python
There are seven combinations of arithmetic operators with the assignment operator "=." The below table gives a glimpse of them.
+= | Addition Assignment Operator |
-= | Subtraction Assignment Operator |
*= | Multiplication Assignment Operator |
/= | Division Assignment Operator |
%= | Modulus Assignment Operator |
//= | Floor Division Assignment Operator |
**= | Exponentiation Assignment Operator |
We'll see all these operators in detail in the upcoming sections.
2. Augmented Bitwise Assignment Operators in Python
There are five combinations of bitwise operators with the assignment operator "=." The below table gives a glimpse of them.
&= | Bitwise AND Assignment Operator |
|= | Bitwise OR Assignment Operator |
^= | Bitwise XOR Assignment Operator |
>>= | Bitwise Right Shift Assignment Operator |
<<= | Bitwise Left Shift Assignment Operator |
Augmented Arithmetic Assignment Operators in Python
1. augmented addition operator (+=).
It adds the right operand to the left operand and assigns the result to the left operand.
Example of Augmented Addition Operator in Python
In this example, we have assigned the value of the sum of x and y to the variable x using the assignment operator (+=).
2. Augmented Subtraction Operator (-=)
It subtracts the right operand from the left operand and assigns the result to the left operand.
Example of Augmented Subtraction Operator in Python
In this example, we have assigned the value of the difference between x and y to the variable x using the assignment operator (-=).
3. Augmented Multiplication Operator (*=)
It multiplies the right operand with the left operand and assigns the result to the left operand.
Example of Augmented Multiplication Operator in Python
In this example, we have assigned the value of the product of x and y to the variable x using the assignment operator (*=).
4. Augmented Division Operator (/=)
It divides the left operand with the right operand and assigns the result to the left operand.
Example of Augmented Division Operator in Python
In this example, we have assigned the value of the result of dividing x by y to the variable x using the assignment operator (/=).
5. Augmented Modulus Operator (%=)
It calculates the modulus of two operands and assigns the result to the left operand.
Example of Augmented Modulus Operator in Python
In this example, we have assigned the value of the modulus of x by y to the variable x using the assignment operator (%=).
6. Augmented Floor division Operator (//=)
It divides the left operand with the right operand and assigns the floor value to the left operand.
Example of Augmented Floor Division Operator in Python
In this example, we have assigned the floor value of the division of x by y to the variable x using the assignment operator (//=).
7. Augmented Exponent Operator (**=)
It calculates the exponent(raise power) value of the left operand raised to the right operand and assigns the floor value to the left operand.
Example of Augmented Exponent Operator in Python
In this example, we have assigned the exponent value of x raised to y to the variable x using the assignment operator (**=).
Augmented Bitwise Assignment Operators in Python
1. augmented bitwise and (&=).
It performs the bitwise AND operation on the left and right operands and assigns the result to the left operand.
Example of Augmented Bitwise AND Operator in Python
In this example, we have assigned the result of x & y to the variable x using the assignment operator (&=).
2. Augmented Bitwise OR (|=)
It performs the bitwise OR operation on the left and right operands and assigns the result to the left operand.
Example of Augmented Bitwise OR Operator in Python
In this example, we have assigned the result of x | y to the variable x using the assignment operator (|=).
3. Augmented Bitwise XOR (^=)
It performs the bitwise XOR operation on the left and right operands and assigns the result to the left operand.
Example of Augmented Bitwise XOR Operator in Python
In this example, we have assigned the result of x ^ y to the variable x using the assignment operator (^=).
4. Augmented Bitwise Right Shift (>>=)
It performs the bitwise right shift operation on the left and right operands and assigns the result to the left operand.
Example of Augmented Bitwise Right Shift Operator in Python
In this example, we have assigned the result of x >>= y to the variable x using the assignment operator (>>=).
5. Augmented Bitwise Left Shift (<<=)
It performs the bitwise left shift operation on the left and right operands and assigns the result to the left operand.
Example of Augmented Bitwise Left Shift Operator in Python
In this example, we have assigned the result of x <<= y to the variable x using the assignment operator (<<=).
Walrus Operator in Python
Python 3.8 introduced the walrus operator (:=) to write an assignment expression. Assignment expressions have a return value that is automatically assigned to a variable.
Syntax of an Assignment Expression
Example of walrus operator in python.
The ":=" operator assigns the value of numbers.pop(0) to the variable num and evaluates it in the Python while loop condition.
Assignment operators are critical fundamental operators that are useful for various operations. They are capable of performing assignment, bitwise, and shift operations. To learn Python effectively, you need to master these operators.
Live Classes Schedule
Software Architecture and Design Training | Jul 28 | SAT, SUN | Filling Fast | ||
.NET Solution Architect Certification Training | Jul 28 | SAT, SUN | Filling Fast | ||
Azure Developer Certification Training | Jul 28 | SAT, SUN | Filling Fast | ||
Advanced Full-Stack .NET Developer Certification Training | Jul 28 | SAT, SUN | Filling Fast | ||
ASP.NET Core Certification Training | Jul 28 | SAT, SUN | Filling Fast | ||
Data Structures and Algorithms Training with C# | Jul 28 | SAT, SUN | Filling Fast | ||
Microsoft Azure Cloud Architect | Aug 11 | SAT, SUN | Filling Fast | ||
Angular Certification Course | Aug 11 | SAT, SUN | Filling Fast | ||
ASP.NET Core Project | Aug 24 | SAT, SUN | Filling Fast |
Can't find convenient schedule? Let us know
About Author
She is passionate about different technologies like JavaScript, React, HTML, CSS, Node.js etc. and likes to share knowledge with the developer community. She holds strong learning skills in keeping herself updated with the changing technologies in her area as well as other technologies like Core Java, Python and Cloud.
We use cookies to make interactions with our websites and services easy and meaningful. Please read our Privacy Policy for more details.
- Python Basics
- Python - Home
- Python - Overview
- Python - History
- Python - Features
- Python vs C++
- Python - Hello World Program
- Python - Application Areas
- Python - Interpreter
- Python - Environment Setup
- Python - Virtual Environment
- Python - Basic Syntax
- Python - Variables
- Python - Data Types
- Python - Type Casting
- Python - Unicode System
- Python - Literals
- Python - Operators
- Python - Arithmetic Operators
- Python - Comparison Operators
Python - Assignment Operators
- Python - Logical Operators
- Python - Bitwise Operators
- Python - Membership Operators
- Python - Identity Operators
- Python - Operator Precedence
- Python - Comments
- Python - User Input
- Python - Numbers
- Python - Booleans
- Python Control Statements
- Python - Control Flow
- Python - Decision Making
- Python - If Statement
- Python - If else
- Python - Nested If
- Python - Match-Case Statement
- Python - Loops
- Python - for Loops
- Python - for-else Loops
- Python - While Loops
- Python - break Statement
- Python - continue Statement
- Python - pass Statement
- Python - Nested Loops
- Python Functions & Modules
- Python - Functions
- Python - Default Arguments
- Python - Keyword Arguments
- Python - Keyword-Only Arguments
- Python - Positional Arguments
- Python - Positional-Only Arguments
- Python - Arbitrary Arguments
- Python - Variables Scope
- Python - Function Annotations
- Python - Modules
- Python - Built in Functions
- Python Strings
- Python - Strings
- Python - Slicing Strings
- Python - Modify Strings
- Python - String Concatenation
- Python - String Formatting
- Python - Escape Characters
- Python - String Methods
- Python - String Exercises
- Python Lists
- Python - Lists
- Python - Access List Items
- Python - Change List Items
- Python - Add List Items
- Python - Remove List Items
- Python - Loop Lists
- Python - List Comprehension
- Python - Sort Lists
- Python - Copy Lists
- Python - Join Lists
- Python - List Methods
- Python - List Exercises
- Python Tuples
- Python - Tuples
- Python - Access Tuple Items
- Python - Update Tuples
- Python - Unpack Tuples
- Python - Loop Tuples
- Python - Join Tuples
- Python - Tuple Methods
- Python - Tuple Exercises
- Python Sets
- Python - Sets
- Python - Access Set Items
- Python - Add Set Items
- Python - Remove Set Items
- Python - Loop Sets
- Python - Join Sets
- Python - Copy Sets
- Python - Set Operators
- Python - Set Methods
- Python - Set Exercises
- Python Dictionaries
- Python - Dictionaries
- Python - Access Dictionary Items
- Python - Change Dictionary Items
- Python - Add Dictionary Items
- Python - Remove Dictionary Items
- Python - Dictionary View Objects
- Python - Loop Dictionaries
- Python - Copy Dictionaries
- Python - Nested Dictionaries
- Python - Dictionary Methods
- Python - Dictionary Exercises
- Python Arrays
- Python - Arrays
- Python - Access Array Items
- Python - Add Array Items
- Python - Remove Array Items
- Python - Loop Arrays
- Python - Copy Arrays
- Python - Reverse Arrays
- Python - Sort Arrays
- Python - Join Arrays
- Python - Array Methods
- Python - Array Exercises
- Python File Handling
- Python - File Handling
- Python - Write to File
- Python - Read Files
- Python - Renaming and Deleting Files
- Python - Directories
- Python - File Methods
- Python - OS File/Directory Methods
- Python - OS Path Methods
- Object Oriented Programming
- Python - OOPs Concepts
- Python - Classes & Objects
- Python - Class Attributes
- Python - Class Methods
- Python - Static Methods
- Python - Constructors
- Python - Access Modifiers
- Python - Inheritance
- Python - Polymorphism
- Python - Method Overriding
- Python - Method Overloading
- Python - Dynamic Binding
- Python - Dynamic Typing
- Python - Abstraction
- Python - Encapsulation
- Python - Interfaces
- Python - Packages
- Python - Inner Classes
- Python - Anonymous Class and Objects
- Python - Singleton Class
- Python - Wrapper Classes
- Python - Enums
- Python - Reflection
- Python Errors & Exceptions
- Python - Syntax Errors
- Python - Exceptions
- Python - try-except Block
- Python - try-finally Block
- Python - Raising Exceptions
- Python - Exception Chaining
- Python - Nested try Block
- Python - User-defined Exception
- Python - Logging
- Python - Assertions
- Python - Built-in Exceptions
- Python Multithreading
- Python - Multithreading
- Python - Thread Life Cycle
- Python - Creating a Thread
- Python - Starting a Thread
- Python - Joining Threads
- Python - Naming Thread
- Python - Thread Scheduling
- Python - Thread Pools
- Python - Main Thread
- Python - Thread Priority
- Python - Daemon Threads
- Python - Synchronizing Threads
- Python Synchronization
- Python - Inter-thread Communication
- Python - Thread Deadlock
- Python - Interrupting a Thread
- Python Networking
- Python - Networking
- Python - Socket Programming
- Python - URL Processing
- Python - Generics
- Python Libraries
- NumPy Tutorial
- Pandas Tutorial
- SciPy Tutorial
- Matplotlib Tutorial
- Django Tutorial
- OpenCV Tutorial
- Python Miscellenous
- Python - Date & Time
- Python - Maths
- Python - Iterators
- Python - Generators
- Python - Closures
- Python - Decorators
- Python - Recursion
- Python - Reg Expressions
- Python - PIP
- Python - Database Access
- Python - Weak References
- Python - Serialization
- Python - Templating
- Python - Output Formatting
- Python - Performance Measurement
- Python - Data Compression
- Python - CGI Programming
- Python - XML Processing
- Python - GUI Programming
- Python - Command-Line Arguments
- Python - Docstrings
- Python - JSON
- Python - Sending Email
- Python - Further Extensions
- Python - Tools/Utilities
- Python - GUIs
- Python Advanced Concepts
- Python - Abstract Base Classes
- Python - Custom Exceptions
- Python - Higher Order Functions
- Python - Object Internals
- Python - Memory Management
- Python - Metaclasses
- Python - Metaprogramming with Metaclasses
- Python - Mocking and Stubbing
- Python - Monkey Patching
- Python - Signal Handling
- Python - Type Hints
- Python - Automation Tutorial
- Python - Humanize Package
- Python - Context Managers
- Python - Coroutines
- Python - Descriptors
- Python - Diagnosing and Fixing Memory Leaks
- Python - Immutable Data Structures
- Python Useful Resources
- Python Compiler
- NumPy Compiler
- Matplotlib Compiler
- SciPy Compiler
- Python - Questions & Answers
- Python - Online Quiz
- Python - Programming Examples
- Python - Quick Guide
- Python - Useful Resources
- Python - Discussion
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
Python Assignment Operator
The = (equal to) symbol is defined as assignment operator in Python. The value of Python expression on its right is assigned to a single variable on its left. The = symbol as in programming in general (and Python in particular) should not be confused with its usage in Mathematics, where it states that the expressions on the either side of the symbol are equal.
Example of Assignment Operator in Python
Consider following Python statements −
At the first instance, at least for somebody new to programming but who knows maths, the statement "a=a+b" looks strange. How could a be equal to "a+b"? However, it needs to be reemphasized that the = symbol is an assignment operator here and not used to show the equality of LHS and RHS.
Because it is an assignment, the expression on right evaluates to 15, the value is assigned to a.
In the statement "a+=b", the two operators "+" and "=" can be combined in a "+=" operator. It is called as add and assign operator. In a single statement, it performs addition of two operands "a" and "b", and result is assigned to operand on left, i.e., "a".
Augmented Assignment Operators in Python
In addition to the simple assignment operator, Python provides few more assignment operators for advanced use. They are called cumulative or augmented assignment operators. In this chapter, we shall learn to use augmented assignment operators defined in Python.
Python has the augmented assignment operators for all arithmetic and comparison operators.
Python augmented assignment operators combines addition and assignment in one statement. Since Python supports mixed arithmetic, the two operands may be of different types. However, the type of left operand changes to the operand of on right, if it is wider.
The += operator is an augmented operator. It is also called cumulative addition operator, as it adds "b" in "a" and assigns the result back to a variable.
The following are the augmented assignment operators in Python:
- Augmented Addition Operator
- Augmented Subtraction Operator
- Augmented Multiplication Operator
- Augmented Division Operator
- Augmented Modulus Operator
- Augmented Exponent Operator
- Augmented Floor division Operator
Augmented Addition Operator (+=)
Following examples will help in understanding how the "+=" operator works −
It will produce the following output −
Augmented Subtraction Operator (-=)
Use -= symbol to perform subtract and assign operations in a single statement. The "a-=b" statement performs "a=a-b" assignment. Operands may be of any number type. Python performs implicit type casting on the object which is narrower in size.
Augmented Multiplication Operator (*=)
The "*=" operator works on similar principle. "a*=b" performs multiply and assign operations, and is equivalent to "a=a*b". In case of augmented multiplication of two complex numbers, the rule of multiplication as discussed in the previous chapter is applicable.
Augmented Division Operator (/=)
The combination symbol "/=" acts as divide and assignment operator, hence "a/=b" is equivalent to "a=a/b". The division operation of int or float operands is float. Division of two complex numbers returns a complex number. Given below are examples of augmented division operator.
Augmented Modulus Operator (%=)
To perform modulus and assignment operation in a single statement, use the %= operator. Like the mod operator, its augmented version also is not supported for complex number.
Augmented Exponent Operator (**=)
The "**=" operator results in computation of "a" raised to "b", and assigning the value back to "a". Given below are some examples −
Augmented Floor division Operator (//=)
For performing floor division and assignment in a single statement, use the "//=" operator. "a//=b" is equivalent to "a=a//b". This operator cannot be used with complex numbers.
Python Assignment Operators
Lesson Contents
Python assignment operators are one of the operator types and assign values to variables . We use arithmetic operators here in combination with a variable.
Let’s take a look at some examples.
Operator Assignment (=)
This is the most basic assignment operator and we used it before in the lessons about lists , tuples , and dictionaries . For example, we can assign a value (integer) to a variable:
Operator Addition (+=)
We can add a number to our variable like this:
Using the above operator is the same as doing this:
The += operator is shorter to write but the end result is the same.
Operator Subtraction (-=)
We can also subtract a value. For example:
Using this operator is the same as doing this:
Operator Multiplication (*=)
We can also use multiplication. We’ll multiply our variable by 4:
Which is similar to:
Operator Division (/=)
Let’s try the divide operator:
This is the same as:
Operator Modulus (%=)
We can also calculate the modulus. How about this:
This is the same as doing it like this:
Operator Exponentiation (**=)
How about exponentiation? Let’s give it a try:
Which is the same as doing it like this:
Operator Floor Division (//=)
The last one, floor division:
You have now learned how to use the Python assignment operators to assign values to variables and how you can use them with arithmetic operators . I hope you enjoyed this lesson. If you have any questions, please leave a comment.
Ask a question or start a discussion by visiting our Community Forum
Python Assignment Operators
In Python, an assignment operator is used to assign a value to a variable. The assignment operator is a single equals sign (=). Here is an example of using the assignment operator to assign a value to a variable:
In this example, the variable x is assigned the value 5.
There are also several compound assignment operators in Python, which are used to perform an operation and assign the result to a variable in a single step. These operators include:
- +=: adds the right operand to the left operand and assigns the result to the left operand
- -=: subtracts the right operand from the left operand and assigns the result to the left operand
- *=: multiplies the left operand by the right operand and assigns the result to the left operand
- /=: divides the left operand by the right operand and assigns the result to the left operand
- %=: calculates the remainder of the left operand divided by the right operand and assigns the result to the left operand
- //=: divides the left operand by the right operand and assigns the result as an integer to the left operand
- **=: raises the left operand to the power of the right operand and assigns the result to the left operand
Here are some examples of using compound assignment operators:
Python Operators: Arithmetic, Assignment, Comparison, Logical, Identity, Membership, Bitwise
Operators are special symbols that perform some operation on operands and returns the result. For example, 5 + 6 is an expression where + is an operator that performs arithmetic add operation on numeric left operand 5 and the right side operand 6 and returns a sum of two operands as a result.
Python includes the operator module that includes underlying methods for each operator. For example, the + operator calls the operator.add(a,b) method.
Above, expression 5 + 6 is equivalent to the expression operator.add(5, 6) and operator.__add__(5, 6) . Many function names are those used for special methods, without the double underscores (dunder methods). For backward compatibility, many of these have functions with the double underscores kept.
Python includes the following categories of operators:
Arithmetic Operators
Assignment operators, comparison operators, logical operators, identity operators, membership test operators, bitwise operators.
Arithmetic operators perform the common mathematical operation on the numeric operands.
The arithmetic operators return the type of result depends on the type of operands, as below.
- If either operand is a complex number, the result is converted to complex;
- If either operand is a floating point number, the result is converted to floating point;
- If both operands are integers, then the result is an integer and no conversion is needed.
The following table lists all the arithmetic operators in Python:
Operation | Operator | Function | Example in Python Shell |
---|---|---|---|
Sum of two operands | + | operator.add(a,b) | |
Left operand minus right operand | - | operator.sub(a,b) | |
* | operator.mul(a,b) | ||
Left operand raised to the power of right | ** | operator.pow(a,b) | |
/ | operator.truediv(a,b) | ||
equivilant to | // | operator.floordiv(a,b) | |
Reminder of | % | operator.mod(a, b) |
The assignment operators are used to assign values to variables. The following table lists all the arithmetic operators in Python:
Operator | Function | Example in Python Shell |
---|---|---|
= | ||
+= | operator.iadd(a,b) | |
-= | operator.isub(a,b) | |
*= | operator.imul(a,b) | |
/= | operator.itruediv(a,b) | |
//= | operator.ifloordiv(a,b) | |
%= | operator.imod(a, b) | |
&= | operator.iand(a, b) | |
|= | operator.ior(a, b) | |
^= | operator.ixor(a, b) | |
>>= | operator.irshift(a, b) | |
<<= | operator.ilshift(a, b) |
The comparison operators compare two operands and return a boolean either True or False. The following table lists comparison operators in Python.
Operator | Function | Description | Example in Python Shell |
---|---|---|---|
> | operator.gt(a,b) | True if the left operand is higher than the right one | |
< | operator.lt(a,b) | True if the left operand is lower than right one | |
== | operator.eq(a,b) | True if the operands are equal | |
!= | operator.ne(a,b) | True if the operands are not equal | |
>= | operator.ge(a,b) | True if the left operand is higher than or equal to the right one | |
<= | operator.le(a,b) | True if the left operand is lower than or equal to the right one |
The logical operators are used to combine two boolean expressions. The logical operations are generally applicable to all objects, and support truth tests, identity tests, and boolean operations.
Operator | Description | Example |
---|---|---|
and | True if both are true | |
or | True if at least one is true | |
not | Returns True if an expression evalutes to false and vice-versa |
The identity operators check whether the two objects have the same id value e.i. both the objects point to the same memory location.
Operator | Function | Description | Example in Python Shell |
---|---|---|---|
is | operator.is_(a,b) | True if both are true | |
is not | operator.is_not(a,b) | True if at least one is true |
The membership test operators in and not in test whether the sequence has a given item or not. For the string and bytes types, x in y is True if and only if x is a substring of y .
Operator | Function | Description | Example in Python Shell |
---|---|---|---|
in | operator.contains(a,b) | Returns True if the sequence contains the specified item else returns False. | |
not in | not operator.contains(a,b) | Returns True if the sequence does not contains the specified item, else returns False. |
Bitwise operators perform operations on binary operands.
Operator | Function | Description | Example in Python Shell |
---|---|---|---|
& | operator.and_(a,b) | Sets each bit to 1 if both bits are 1. | |
| | operator.or_(a,b) | Sets each bit to 1 if one of two bits is 1. | |
^ | operator.xor(a,b) | Sets each bit to 1 if only one of two bits is 1. | |
~ | operator.invert(a) | Inverts all the bits. | |
<< | operator.lshift(a,b) | Shift left by pushing zeros in from the right and let the leftmost bits fall off. | |
>> | operator.rshift(a,b) | Shift right by pushing copies of the leftmost bit in from the left, and let the rightmost bits fall off. |
- Compare strings in Python
- Convert file data to list
- Convert User Input to a Number
- Convert String to Datetime in Python
- How to call external commands in Python?
- How to count the occurrences of a list item?
- How to flatten list in Python?
- How to merge dictionaries in Python?
- How to pass value by reference in Python?
- Remove duplicate items from list in Python
- More Python articles
We are a team of passionate developers, educators, and technology enthusiasts who, with their combined expertise and experience, create in -depth, comprehensive, and easy to understand tutorials.We focus on a blend of theoretical explanations and practical examples to encourages hands - on learning. Visit About Us page for more information.
- Python Questions & Answers
- Python Skill Test
- Python Latest Articles
Python Assignment Operators
Python Assignment Operators | Example | Explanation |
---|---|---|
= | x= 25 | Value 25 is assigned to x |
+= | x += 25 | This is same as x = x + 25 |
-= | x -= 25 | Same as x = x – 25 |
*= | x *= 25 | This is same as x = x * 25 |
/= | x /= 25 | Same as x = x / 25 |
%= | x %= 25 | This is identical to x = x % 25 |
//= | x //= 25 | Same as x = x // 25 |
**= | x **= 25 | This is same as x = x ** 25 |
&= | x &= 25 | This is same as x = x & 25 |
|= | x |= 25 | This is same as x = x | 25 |
^= | x ^= 25 | Same as x = x ^ 25 |
<<= | x <<= 25 | This is same as x = x << 25 |
>>= | x >>= 25 | Same as x = x >> 25 |
Python Assignment Operators Example
- Case Studies
- Our Pricing
- Do my Programming Homework
- Java Homework Help
- HTML Homework Help
- Do my computer science homework
- C++ Homework Help
- C Homework Help
- Python Assignment Help
- Android Assignment help
- Database Homework Help
- PHP Assignment Help
- JavaScript Assignment Help
- R Assignment Help
- Node.Js Homework Help
- Data Structures Assignment Help
- Machine Learning Assignment Help
- MATLAB Assignment Help
- C Sharp Assignment Help
- Operating System Assignment Help
- Assembly Language Assignment Help
- Scala Assignment Help
- Visual Basic Assignment Help
- Live Java Tutoring
- Python Tutoring
- Our Experts
- Testimonials
- Submit Your Assignment
Understanding The Assignment Operators In Python
While learning any Programming Language, the basics should be clear to you. This fits well with the Python programming language. The concept of Assignment Operators will be the best to start. That is why learning “Assignment Operators In Python” is necessary.
Among many other beginner concepts in Python Language, the Operators get more concentration because this will frame the future path in your career. So, if you are going to start learning Python, you should focus more on Python Assignment Operators.
This article will discuss the basics of Python Assignment Operators. Also, we will perform operations with Python Assignment Operators for clear understanding. So, let’s start this interesting journey.
If you encounter any challenges in grasping these operators, don’t hesitate to seek Python help from the experts at CodingZap.
Summary or Key Highlights:
Operator is a Mathematical Operations with two variables or Oparends & one Operator.
There are many Operators in Python like Assignment Operators, Bitwise Operators, Logical Operations, etc.
The key task of the Python Assignment Operators is to assign values to the variables.
To assign values with Python Assignment Operators, you need to know the relationship between Operators and Operands .
Python Assignment Operators can be created with other operators in Python.
What Are Assignment Operators In Python? Read Below
The operator is a simple Mathematical Expression where Two Operands & One Operator are used to make one complete expression. The Operator is placed in the middle & there are Left-Side Operand and Right-Side Operand.
In the expression “a+b”, “+” is the operator, and “a” and “b” are the operands. Assignment operators are a fundamental concept in Python and most programming languages. They are used to assign values to variables, as well as initialize and update them.
For the Coding Language, sometimes the Right-Side Operand can be a value as well. The main role of the Basic Assignment Operator is to assign values to the Left Operand from the Right Operand. If the Left Operand is present as a variable, then only the complete process can be done.
How To Use Assignment Operator In Python?
Now, after the definition, we are coming to the technique to use Python Assignment Operators. That means here, we will discuss the syntax of the Python Assignment Operators. So for that purpose, check the following example.
From the above syntax, the Python Assignment Variable can be defined. You can notice that the Python Assignment Operator can be differentiated into three parts. Let us check those three parts here.
The left-side operand of an assignment statement must always and only be a variable.
Then comes the assignment operator itself.
The right-side operand can be a value, an expression, or an object.
What Are Different Assignment Operators In Python?
Now, it is time to move ahead to the central discussion point. Here, we will implement a Python Assignment Operator for each class. There are multiple types of Python Assignment Operators are present. And each of the cases, the Assigning Values will behave differently.
Before moving to Other assignment operators, let us start with the very simple one. This is known as the Simple Assignment Operator or Basic Assignment Operator.
1. Simple Assignment Operator or Basic Assignment Operator:
It is a very simple implementation process. Here, we will follow the Syntax declared above and implement the Python Code. We will just assign the value to the left to some new variables. It is also known as the Primary Assignment Operator.
2. Multiple And Parallel Assignment Operator:
Now, the Multiple And Parallel Assignment is not mentioned as the categories of the Assignment Operator. However, we can still write them in the section. We can say that, they are the variations of the Simple Equal Operator.
Short Explanation For Multiple Assignments:
In the above code, the integer value 45 is assigned to all the variables a,b,c. The data type of all the variables in a multiple-assignment statement must be the same.
Short Explanation For Parallel Assignment:
In parallel assignments, we can assign different values to different variables using comma-separated variables and values on either side of the assignment operator. The values are stored in the order of writing the pairs. The variable types need not be the same in parallel assignments.
3. Addition Assignment Operator:
This operator adds the left and the right operands and assigns the resulting value to the variable on the left. An example would be a += b which will equate to a = a+b .
It is important to note that only the value of “a” will change, whereas the value of “b” will remain the same. This is because the sum of “a” and “b” is finally stored in the variable “a”.
Short Explanation:
In the above code, we initialized 2 variables and added the value of the second variable to the first one using the add assignment operator. Note that the value of “a” changes, but the value of “b” remains the same.
4. Subtraction Assignment Operator:
After Addition One, it is time to move to the Subtraction Operation . This operator subtracts the right operand from the left and assigns the resulting value to the variable on the left. The working process is nearly the same as the above one.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. Then, we subtracted the value of “b” from “a” using the subtract assignment operator. The final expression equated to “a=a-b”. At last, we printed the final values of “a” and “b”.
5. Multiplication Assignment Operator:
Now, it is time to discuss the Multiplication Assignment Operation which is similar to the above one. The multiplication assignment operator is used to multiply the right operand with the left and assign the resulting value to the variable on the left.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. Then, we multiplied the values of “a” and “b” using the multiplication equal operator. The final expression equated to “a=a*b”. At last, we printed the final values of “a” and “b” to check the resulting values.
6. Division Assignment Operator:
Just like the previous three operators, the Division Operator works the same. Just instead of other operators, we have to put the Disivion Symbol there.
The Division Assignment Operator divides the left-hand operand from the right and assigns the resulting value to the left-hand side.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. Then, we divided “a” by “b” using the division assignment operator. The final expression equated to “a=a/b”. At last, we printed the final values of “a” and “b”.
7. Floor Division Assignment Operator:
Now, you have seen the Division Operator. Now, it is time to move to the Floor Division Operator. This is quite different from the simple division operator.
The floor division operator divides the operand on the left-hand operand from the right and rounds the value to the greatest integer value less than or equal to the resultant value. This value is then stored in the left-hand side operand.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. Then, we divided “a” by “b” using the division assignment operator. The final expression equated to “a=a//b”. At last, we printed the final values of “a” and “b”.
8. Modulus Assignment Operator:
In this case, the Modulus Assignment Operator is defined with the help of the Modulus and Equal Operator. That means the Simple Modulus and Assignment or Equal Operator will be used to get the Modulus value after dividing.
The modulus assignment operator is used to extract the remainder after dividing the operand on the left-hand side operand from the right. The remainder is then stored in the operand on the left-hand side operand.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. We then used the Modulus Equal Operator to get the remainder of the division “a/b”, and store the resulting value in “a”. At last, we printed the final values of “a” and “b”.
9. Exponentiation Assignment Operator:
You might know the Power Operation in Mathematics! The same is present in Python Coding Language as well. This operator is used to get the Power of the Left Operand. This is the operator that can be used for various operations in the future.
This operator calculates the exponent of the left operand raised to the power of the right-side operand, which is then stored in the operand on the left.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. We then used the exponentiation assignment operator to get the value of “a” raised to the power of “b”, and store the resulting value in “a”. At last, we printed the final values of “a” and “b”.
10. Bitwise And Assignment Operator:
You might have come across the And Operator where the Special Symbol “&” is used. It is mostly used in the Computer Organization subject. However, it can be used with the Equal Operator. This operator performs the And Operation in between Left Operand & Ride-Side Operand.
And it will assign the result to the left operand. That men’s, the Left Side is very important in this case as well.
In the above code, we initialized the 2 variables “a” and “b” and printed their values for reference. We then used the bitwise AND assignment operator to get the bitwise AND of “a” and “b”, and store the resulting value in “a”. At last, we printed the final values of “a” and “b”.
What Are Common Pitfalls With Assignment Operators And How to Avoid Them?
Now, after all the above discussion, before we end the topic, we should share some of the challenges that you may face while working on the Assignment Operators. We are going to list all the problems that as a beginner, you might face. So, let us check the following points.
If there are mutable objects like List or Dictionary, then you should be careful to make sudden changes there as it might cause problems later.
You should not declare another variable in the Inner Scope of the program. If you done so, there will be an Error before executing the code.
If you are doing the changes in the Global Variable with Assignment Operators, then there can be consequences in the entire code. So, you have to be very careful.
However, we understand your situation. And we are not going to leave you by giving the list of pitfalls. We will help you to give Some Tips To Overcome such a problem.
Tips that can be used to overcome such situations:
If you are using mutable objects, then the NONE should be used at the time of declaration to avoid the problem.
Always use a different name or name to depict the logic to overcome the situation to use the same name. You can use this trick for all languages.
If you are modifying the Global Variable inside the function, then use the keyword properly. Hence, there will not be any kind of issues.
Conclusion:
As we can see, it is very important to know the “Assignment Operators In Python”.
Operators are the fundamental part of any Coding Language that as a beginner you should have to practice. If the Python Operator Concept becomes clear to you, all the other problems can easily be solved.
There are many reasons why students look for assignment help online like difficulty in understanding the assignment, time limitation, etc. So, if you’re also looking then you can always hire CodinngZap experts.
Additionally, consider hiring Python tutors to accelerate your learning journey and gain personalized guidance along the way.
Assignment Operators assign the value to the Left Operand from the Right-Hand Side.
Assignment Operators assign the result to the left-hand side along with making all the changes.
Assignment Operators can be utilized with other Operators in Python as well.
As the Assignment Operators can assign the result after making prompt calculations, they can be divided into categories.
In each of the cases, before assigning value to the left, the Primary Operations like Addition, Multiplication, Substractions, etc. are done first, then the Assigning Operation.
Sounetra Ghosal
Leave a comment cancel reply.
Your email address will not be published. Required fields are marked *
Our best Coding Help Services
- Do my programming homework
- Computer Science hw help
- Database homework assistance
- HTML coding help
- Android Help
- Java Assignment Help
- C programming Help
- Python Coding Help
- Assembly Coding Help
- Node.Js help
- C Sharp help
- Machine Learning task help
- PHP project help
- Operating System Help
CodingZap is founded back in 2015 with a mindset to provide genuine programming help to students across the globe. We cater to a broad range of programming homework help services to students and techies who are struggling with their code.
Programming Help Expertise
Contact us now.
- HQ USA: 920 Beach Park Blvd, Foster City, USA
- +1 (332) 895-6153
- [email protected]
Important Links
Copyright 2015-2024 CodingZap Technologies Private Limited- All rights reserved.
- +919035109861
Logical Python
Effective Python Tutorials
Python Assignment Operators
Introduction to python assignment operators.
Assignment Operators are used for assigning values to the variables. We can also say that assignment operators are used to assign values to the left-hand side operand. For example, in the below table, we are assigning a value to variable ‘a’, which is the left-side operand.
Operator | Description | Example | Equivalent |
---|---|---|---|
= | a = 2 | a = 2 | |
+= | a += 2 | a = a + 2 | |
-= | a -= 2 | a = a – 2 | |
*= | a *= 2 | a = a * 2 | |
/= | a /= 2 | a = a / 2 | |
%= | a %= 2 | a = a % 2 | |
//= | a //= 2 | a = a // 2 | |
**= | a **= 2 | a = a ** 2 | |
&= | a &= 2 | a = a & 2 | |
|= | a |= 2 | a = a | 2 | |
^= | a ^= 2 | a = a ^ 2 | |
>>= | a >>= 2 | a = a >> 2 | |
<<= | a <<= 3 | a = a << 2 |
Assignment Operators
Assignment operator.
Equal to sign ‘=’ is used as an assignment operator. It assigns values of the right-hand side expression to the variable or operand present on the left-hand side.
Assigns value 3 to variable ‘a’.
Addition and Assignment Operator
The addition and assignment operator adds left-side and right-side operands and then the sum is assigned to the left-hand side operand.
Below code is equivalent to: a = a + 2.
Subtraction and Assignment Operator
The subtraction and assignment operator subtracts the right-side operand from the left-side operand, and then the result is assigned to the left-hand side operand.
Below code is equivalent to: a = a – 2.
Multiplication and Assignment Operator
The multiplication and assignment operator multiplies the right-side operand with the left-side operand, and then the result is assigned to the left-hand side operand.
Below code is equivalent to: a = a * 2.
Division and Assignment Operator
The division and assignment operator divides the left-side operand with the right-side operand, and then the result is assigned to the left-hand side operand.
Below code is equivalent to: a = a / 2.
Modulus and Assignment Operator
The modulus and assignment operator divides the left-side operand with the right-side operand, and then the remainder is assigned to the left-hand side operand.
Below code is equivalent to: a = a % 3.
Floor Division and Assignment Operator
The floor division and assignment operator divides the left side operand with the right side operand. The result is rounded down to the closest integer value(i.e. floor value) and is assigned to the left-hand side operand.
Below code is equivalent to: a = a // 3.
Exponential and Assignment Operator
The exponential and assignment operator raises the left-side operand to the power of the right-side operand, and the result is assigned to the left-hand side operand.
Below code is equivalent to: a = a ** 3.
Bitwise AND and Assignment Operator
Bitwise AND and assignment operator performs bitwise AND operation on both the operands and assign the result to the left-hand side operand.
Below code is equivalent to: a = a & 3.
Illustration:
Numeric Value | Binary Value | |
---|---|---|
2 | 010 | |
3 | 011 | |
Bitwise OR and Assignment Operator
Bitwise OR and assignment operator performs bitwise OR operation on both the operands and assign the result to the left-hand side operand.
Below code is equivalent to: a = a | 3.
Bitwise XOR and Assignment Operator
Bitwise XOR and assignment operator performs bitwise XOR operation on both the operands and assign the result to the left-hand side operand.
Below code is equivalent to: a = a ^ 3.
Bitwise Right Shift and Assignment Operator
Bitwise right shift and assignment operator right shifts the left operand by the right operand positions and assigns the result to the left-hand side operand.
Below code is equivalent to: a = a >> 1.
Numeric Input | Binary Value | Right shift by 1 | Numeric Output |
---|---|---|---|
2 | 0010 | 0001 | 1 |
4 | 0100 | 0010 | 2 |
Bitwise Left Shift and Assignment Operator
Bitwise left shift and assignment operator left shifts the left operand by the right operand positions and assigns the result to the left-hand side operand.
Below code is equivalent to: a = a << 1.
Numeric Input | Bitwise Value | Left shift by 1 | Numeric Output |
---|---|---|---|
2 | 0010 | 0100 | 4 |
4 | 0100 | 1000 | 8 |
References:
- Different Assignment operators in Python
- Assignment Operator in Python
- Assignment Expressions
Python Enhancement Proposals
- Python »
- PEP Index »
PEP 572 – Assignment Expressions
The importance of real code, exceptional cases, scope of the target, relative precedence of :=, change to evaluation order, differences between assignment expressions and assignment statements, specification changes during implementation, _pydecimal.py, datetime.py, sysconfig.py, simplifying list comprehensions, capturing condition values, changing the scope rules for comprehensions, alternative spellings, special-casing conditional statements, special-casing comprehensions, lowering operator precedence, allowing commas to the right, always requiring parentheses, why not just turn existing assignment into an expression, with assignment expressions, why bother with assignment statements, why not use a sublocal scope and prevent namespace pollution, style guide recommendations, acknowledgements, a numeric example, appendix b: rough code translations for comprehensions, appendix c: no changes to scope semantics.
This is a proposal for creating a way to assign to variables within an expression using the notation NAME := expr .
As part of this change, there is also an update to dictionary comprehension evaluation order to ensure key expressions are executed before value expressions (allowing the key to be bound to a name and then re-used as part of calculating the corresponding value).
During discussion of this PEP, the operator became informally known as “the walrus operator”. The construct’s formal name is “Assignment Expressions” (as per the PEP title), but they may also be referred to as “Named Expressions” (e.g. the CPython reference implementation uses that name internally).
Naming the result of an expression is an important part of programming, allowing a descriptive name to be used in place of a longer expression, and permitting reuse. Currently, this feature is available only in statement form, making it unavailable in list comprehensions and other expression contexts.
Additionally, naming sub-parts of a large expression can assist an interactive debugger, providing useful display hooks and partial results. Without a way to capture sub-expressions inline, this would require refactoring of the original code; with assignment expressions, this merely requires the insertion of a few name := markers. Removing the need to refactor reduces the likelihood that the code be inadvertently changed as part of debugging (a common cause of Heisenbugs), and is easier to dictate to another programmer.
During the development of this PEP many people (supporters and critics both) have had a tendency to focus on toy examples on the one hand, and on overly complex examples on the other.
The danger of toy examples is twofold: they are often too abstract to make anyone go “ooh, that’s compelling”, and they are easily refuted with “I would never write it that way anyway”.
The danger of overly complex examples is that they provide a convenient strawman for critics of the proposal to shoot down (“that’s obfuscated”).
Yet there is some use for both extremely simple and extremely complex examples: they are helpful to clarify the intended semantics. Therefore, there will be some of each below.
However, in order to be compelling , examples should be rooted in real code, i.e. code that was written without any thought of this PEP, as part of a useful application, however large or small. Tim Peters has been extremely helpful by going over his own personal code repository and picking examples of code he had written that (in his view) would have been clearer if rewritten with (sparing) use of assignment expressions. His conclusion: the current proposal would have allowed a modest but clear improvement in quite a few bits of code.
Another use of real code is to observe indirectly how much value programmers place on compactness. Guido van Rossum searched through a Dropbox code base and discovered some evidence that programmers value writing fewer lines over shorter lines.
Case in point: Guido found several examples where a programmer repeated a subexpression, slowing down the program, in order to save one line of code, e.g. instead of writing:
they would write:
Another example illustrates that programmers sometimes do more work to save an extra level of indentation:
This code tries to match pattern2 even if pattern1 has a match (in which case the match on pattern2 is never used). The more efficient rewrite would have been:
Syntax and semantics
In most contexts where arbitrary Python expressions can be used, a named expression can appear. This is of the form NAME := expr where expr is any valid Python expression other than an unparenthesized tuple, and NAME is an identifier.
The value of such a named expression is the same as the incorporated expression, with the additional side-effect that the target is assigned that value:
There are a few places where assignment expressions are not allowed, in order to avoid ambiguities or user confusion:
This rule is included to simplify the choice for the user between an assignment statement and an assignment expression – there is no syntactic position where both are valid.
Again, this rule is included to avoid two visually similar ways of saying the same thing.
This rule is included to disallow excessively confusing code, and because parsing keyword arguments is complex enough already.
This rule is included to discourage side effects in a position whose exact semantics are already confusing to many users (cf. the common style recommendation against mutable default values), and also to echo the similar prohibition in calls (the previous bullet).
The reasoning here is similar to the two previous cases; this ungrouped assortment of symbols and operators composed of : and = is hard to read correctly.
This allows lambda to always bind less tightly than := ; having a name binding at the top level inside a lambda function is unlikely to be of value, as there is no way to make use of it. In cases where the name will be used more than once, the expression is likely to need parenthesizing anyway, so this prohibition will rarely affect code.
This shows that what looks like an assignment operator in an f-string is not always an assignment operator. The f-string parser uses : to indicate formatting options. To preserve backwards compatibility, assignment operator usage inside of f-strings must be parenthesized. As noted above, this usage of the assignment operator is not recommended.
An assignment expression does not introduce a new scope. In most cases the scope in which the target will be bound is self-explanatory: it is the current scope. If this scope contains a nonlocal or global declaration for the target, the assignment expression honors that. A lambda (being an explicit, if anonymous, function definition) counts as a scope for this purpose.
There is one special case: an assignment expression occurring in a list, set or dict comprehension or in a generator expression (below collectively referred to as “comprehensions”) binds the target in the containing scope, honoring a nonlocal or global declaration for the target in that scope, if one exists. For the purpose of this rule the containing scope of a nested comprehension is the scope that contains the outermost comprehension. A lambda counts as a containing scope.
The motivation for this special case is twofold. First, it allows us to conveniently capture a “witness” for an any() expression, or a counterexample for all() , for example:
Second, it allows a compact way of updating mutable state from a comprehension, for example:
However, an assignment expression target name cannot be the same as a for -target name appearing in any comprehension containing the assignment expression. The latter names are local to the comprehension in which they appear, so it would be contradictory for a contained use of the same name to refer to the scope containing the outermost comprehension instead.
For example, [i := i+1 for i in range(5)] is invalid: the for i part establishes that i is local to the comprehension, but the i := part insists that i is not local to the comprehension. The same reason makes these examples invalid too:
While it’s technically possible to assign consistent semantics to these cases, it’s difficult to determine whether those semantics actually make sense in the absence of real use cases. Accordingly, the reference implementation [1] will ensure that such cases raise SyntaxError , rather than executing with implementation defined behaviour.
This restriction applies even if the assignment expression is never executed:
For the comprehension body (the part before the first “for” keyword) and the filter expression (the part after “if” and before any nested “for”), this restriction applies solely to target names that are also used as iteration variables in the comprehension. Lambda expressions appearing in these positions introduce a new explicit function scope, and hence may use assignment expressions with no additional restrictions.
Due to design constraints in the reference implementation (the symbol table analyser cannot easily detect when names are re-used between the leftmost comprehension iterable expression and the rest of the comprehension), named expressions are disallowed entirely as part of comprehension iterable expressions (the part after each “in”, and before any subsequent “if” or “for” keyword):
A further exception applies when an assignment expression occurs in a comprehension whose containing scope is a class scope. If the rules above were to result in the target being assigned in that class’s scope, the assignment expression is expressly invalid. This case also raises SyntaxError :
(The reason for the latter exception is the implicit function scope created for comprehensions – there is currently no runtime mechanism for a function to refer to a variable in the containing class scope, and we do not want to add such a mechanism. If this issue ever gets resolved this special case may be removed from the specification of assignment expressions. Note that the problem already exists for using a variable defined in the class scope from a comprehension.)
See Appendix B for some examples of how the rules for targets in comprehensions translate to equivalent code.
The := operator groups more tightly than a comma in all syntactic positions where it is legal, but less tightly than all other operators, including or , and , not , and conditional expressions ( A if C else B ). As follows from section “Exceptional cases” above, it is never allowed at the same level as = . In case a different grouping is desired, parentheses should be used.
The := operator may be used directly in a positional function call argument; however it is invalid directly in a keyword argument.
Some examples to clarify what’s technically valid or invalid:
Most of the “valid” examples above are not recommended, since human readers of Python source code who are quickly glancing at some code may miss the distinction. But simple cases are not objectionable:
This PEP recommends always putting spaces around := , similar to PEP 8 ’s recommendation for = when used for assignment, whereas the latter disallows spaces around = used for keyword arguments.)
In order to have precisely defined semantics, the proposal requires evaluation order to be well-defined. This is technically not a new requirement, as function calls may already have side effects. Python already has a rule that subexpressions are generally evaluated from left to right. However, assignment expressions make these side effects more visible, and we propose a single change to the current evaluation order:
- In a dict comprehension {X: Y for ...} , Y is currently evaluated before X . We propose to change this so that X is evaluated before Y . (In a dict display like {X: Y} this is already the case, and also in dict((X, Y) for ...) which should clearly be equivalent to the dict comprehension.)
Most importantly, since := is an expression, it can be used in contexts where statements are illegal, including lambda functions and comprehensions.
Conversely, assignment expressions don’t support the advanced features found in assignment statements:
- Multiple targets are not directly supported: x = y = z = 0 # Equivalent: (z := (y := (x := 0)))
- Single assignment targets other than a single NAME are not supported: # No equivalent a [ i ] = x self . rest = []
- Priority around commas is different: x = 1 , 2 # Sets x to (1, 2) ( x := 1 , 2 ) # Sets x to 1
- Iterable packing and unpacking (both regular or extended forms) are not supported: # Equivalent needs extra parentheses loc = x , y # Use (loc := (x, y)) info = name , phone , * rest # Use (info := (name, phone, *rest)) # No equivalent px , py , pz = position name , phone , email , * other_info = contact
- Inline type annotations are not supported: # Closest equivalent is "p: Optional[int]" as a separate declaration p : Optional [ int ] = None
- Augmented assignment is not supported: total += tax # Equivalent: (total := total + tax)
The following changes have been made based on implementation experience and additional review after the PEP was first accepted and before Python 3.8 was released:
- for consistency with other similar exceptions, and to avoid locking in an exception name that is not necessarily going to improve clarity for end users, the originally proposed TargetScopeError subclass of SyntaxError was dropped in favour of just raising SyntaxError directly. [3]
- due to a limitation in CPython’s symbol table analysis process, the reference implementation raises SyntaxError for all uses of named expressions inside comprehension iterable expressions, rather than only raising them when the named expression target conflicts with one of the iteration variables in the comprehension. This could be revisited given sufficiently compelling examples, but the extra complexity needed to implement the more selective restriction doesn’t seem worthwhile for purely hypothetical use cases.
Examples from the Python standard library
env_base is only used on these lines, putting its assignment on the if moves it as the “header” of the block.
- Current: env_base = os . environ . get ( "PYTHONUSERBASE" , None ) if env_base : return env_base
- Improved: if env_base := os . environ . get ( "PYTHONUSERBASE" , None ): return env_base
Avoid nested if and remove one indentation level.
- Current: if self . _is_special : ans = self . _check_nans ( context = context ) if ans : return ans
- Improved: if self . _is_special and ( ans := self . _check_nans ( context = context )): return ans
Code looks more regular and avoid multiple nested if. (See Appendix A for the origin of this example.)
- Current: reductor = dispatch_table . get ( cls ) if reductor : rv = reductor ( x ) else : reductor = getattr ( x , "__reduce_ex__" , None ) if reductor : rv = reductor ( 4 ) else : reductor = getattr ( x , "__reduce__" , None ) if reductor : rv = reductor () else : raise Error ( "un(deep)copyable object of type %s " % cls )
- Improved: if reductor := dispatch_table . get ( cls ): rv = reductor ( x ) elif reductor := getattr ( x , "__reduce_ex__" , None ): rv = reductor ( 4 ) elif reductor := getattr ( x , "__reduce__" , None ): rv = reductor () else : raise Error ( "un(deep)copyable object of type %s " % cls )
tz is only used for s += tz , moving its assignment inside the if helps to show its scope.
- Current: s = _format_time ( self . _hour , self . _minute , self . _second , self . _microsecond , timespec ) tz = self . _tzstr () if tz : s += tz return s
- Improved: s = _format_time ( self . _hour , self . _minute , self . _second , self . _microsecond , timespec ) if tz := self . _tzstr (): s += tz return s
Calling fp.readline() in the while condition and calling .match() on the if lines make the code more compact without making it harder to understand.
- Current: while True : line = fp . readline () if not line : break m = define_rx . match ( line ) if m : n , v = m . group ( 1 , 2 ) try : v = int ( v ) except ValueError : pass vars [ n ] = v else : m = undef_rx . match ( line ) if m : vars [ m . group ( 1 )] = 0
- Improved: while line := fp . readline (): if m := define_rx . match ( line ): n , v = m . group ( 1 , 2 ) try : v = int ( v ) except ValueError : pass vars [ n ] = v elif m := undef_rx . match ( line ): vars [ m . group ( 1 )] = 0
A list comprehension can map and filter efficiently by capturing the condition:
Similarly, a subexpression can be reused within the main expression, by giving it a name on first use:
Note that in both cases the variable y is bound in the containing scope (i.e. at the same level as results or stuff ).
Assignment expressions can be used to good effect in the header of an if or while statement:
Particularly with the while loop, this can remove the need to have an infinite loop, an assignment, and a condition. It also creates a smooth parallel between a loop which simply uses a function call as its condition, and one which uses that as its condition but also uses the actual value.
An example from the low-level UNIX world:
Rejected alternative proposals
Proposals broadly similar to this one have come up frequently on python-ideas. Below are a number of alternative syntaxes, some of them specific to comprehensions, which have been rejected in favour of the one given above.
A previous version of this PEP proposed subtle changes to the scope rules for comprehensions, to make them more usable in class scope and to unify the scope of the “outermost iterable” and the rest of the comprehension. However, this part of the proposal would have caused backwards incompatibilities, and has been withdrawn so the PEP can focus on assignment expressions.
Broadly the same semantics as the current proposal, but spelled differently.
Since EXPR as NAME already has meaning in import , except and with statements (with different semantics), this would create unnecessary confusion or require special-casing (e.g. to forbid assignment within the headers of these statements).
(Note that with EXPR as VAR does not simply assign the value of EXPR to VAR – it calls EXPR.__enter__() and assigns the result of that to VAR .)
Additional reasons to prefer := over this spelling include:
- In if f(x) as y the assignment target doesn’t jump out at you – it just reads like if f x blah blah and it is too similar visually to if f(x) and y .
- import foo as bar
- except Exc as var
- with ctxmgr() as var
To the contrary, the assignment expression does not belong to the if or while that starts the line, and we intentionally allow assignment expressions in other contexts as well.
- NAME = EXPR
- if NAME := EXPR
reinforces the visual recognition of assignment expressions.
This syntax is inspired by languages such as R and Haskell, and some programmable calculators. (Note that a left-facing arrow y <- f(x) is not possible in Python, as it would be interpreted as less-than and unary minus.) This syntax has a slight advantage over ‘as’ in that it does not conflict with with , except and import , but otherwise is equivalent. But it is entirely unrelated to Python’s other use of -> (function return type annotations), and compared to := (which dates back to Algol-58) it has a much weaker tradition.
This has the advantage that leaked usage can be readily detected, removing some forms of syntactic ambiguity. However, this would be the only place in Python where a variable’s scope is encoded into its name, making refactoring harder.
Execution order is inverted (the indented body is performed first, followed by the “header”). This requires a new keyword, unless an existing keyword is repurposed (most likely with: ). See PEP 3150 for prior discussion on this subject (with the proposed keyword being given: ).
This syntax has fewer conflicts than as does (conflicting only with the raise Exc from Exc notation), but is otherwise comparable to it. Instead of paralleling with expr as target: (which can be useful but can also be confusing), this has no parallels, but is evocative.
One of the most popular use-cases is if and while statements. Instead of a more general solution, this proposal enhances the syntax of these two statements to add a means of capturing the compared value:
This works beautifully if and ONLY if the desired condition is based on the truthiness of the captured value. It is thus effective for specific use-cases (regex matches, socket reads that return '' when done), and completely useless in more complicated cases (e.g. where the condition is f(x) < 0 and you want to capture the value of f(x) ). It also has no benefit to list comprehensions.
Advantages: No syntactic ambiguities. Disadvantages: Answers only a fraction of possible use-cases, even in if / while statements.
Another common use-case is comprehensions (list/set/dict, and genexps). As above, proposals have been made for comprehension-specific solutions.
This brings the subexpression to a location in between the ‘for’ loop and the expression. It introduces an additional language keyword, which creates conflicts. Of the three, where reads the most cleanly, but also has the greatest potential for conflict (e.g. SQLAlchemy and numpy have where methods, as does tkinter.dnd.Icon in the standard library).
As above, but reusing the with keyword. Doesn’t read too badly, and needs no additional language keyword. Is restricted to comprehensions, though, and cannot as easily be transformed into “longhand” for-loop syntax. Has the C problem that an equals sign in an expression can now create a name binding, rather than performing a comparison. Would raise the question of why “with NAME = EXPR:” cannot be used as a statement on its own.
As per option 2, but using as rather than an equals sign. Aligns syntactically with other uses of as for name binding, but a simple transformation to for-loop longhand would create drastically different semantics; the meaning of with inside a comprehension would be completely different from the meaning as a stand-alone statement, while retaining identical syntax.
Regardless of the spelling chosen, this introduces a stark difference between comprehensions and the equivalent unrolled long-hand form of the loop. It is no longer possible to unwrap the loop into statement form without reworking any name bindings. The only keyword that can be repurposed to this task is with , thus giving it sneakily different semantics in a comprehension than in a statement; alternatively, a new keyword is needed, with all the costs therein.
There are two logical precedences for the := operator. Either it should bind as loosely as possible, as does statement-assignment; or it should bind more tightly than comparison operators. Placing its precedence between the comparison and arithmetic operators (to be precise: just lower than bitwise OR) allows most uses inside while and if conditions to be spelled without parentheses, as it is most likely that you wish to capture the value of something, then perform a comparison on it:
Once find() returns -1, the loop terminates. If := binds as loosely as = does, this would capture the result of the comparison (generally either True or False ), which is less useful.
While this behaviour would be convenient in many situations, it is also harder to explain than “the := operator behaves just like the assignment statement”, and as such, the precedence for := has been made as close as possible to that of = (with the exception that it binds tighter than comma).
Some critics have claimed that the assignment expressions should allow unparenthesized tuples on the right, so that these two would be equivalent:
(With the current version of the proposal, the latter would be equivalent to ((point := x), y) .)
However, adopting this stance would logically lead to the conclusion that when used in a function call, assignment expressions also bind less tight than comma, so we’d have the following confusing equivalence:
The less confusing option is to make := bind more tightly than comma.
It’s been proposed to just always require parentheses around an assignment expression. This would resolve many ambiguities, and indeed parentheses will frequently be needed to extract the desired subexpression. But in the following cases the extra parentheses feel redundant:
Frequently Raised Objections
C and its derivatives define the = operator as an expression, rather than a statement as is Python’s way. This allows assignments in more contexts, including contexts where comparisons are more common. The syntactic similarity between if (x == y) and if (x = y) belies their drastically different semantics. Thus this proposal uses := to clarify the distinction.
The two forms have different flexibilities. The := operator can be used inside a larger expression; the = statement can be augmented to += and its friends, can be chained, and can assign to attributes and subscripts.
Previous revisions of this proposal involved sublocal scope (restricted to a single statement), preventing name leakage and namespace pollution. While a definite advantage in a number of situations, this increases complexity in many others, and the costs are not justified by the benefits. In the interests of language simplicity, the name bindings created here are exactly equivalent to any other name bindings, including that usage at class or module scope will create externally-visible names. This is no different from for loops or other constructs, and can be solved the same way: del the name once it is no longer needed, or prefix it with an underscore.
(The author wishes to thank Guido van Rossum and Christoph Groth for their suggestions to move the proposal in this direction. [2] )
As expression assignments can sometimes be used equivalently to statement assignments, the question of which should be preferred will arise. For the benefit of style guides such as PEP 8 , two recommendations are suggested.
- If either assignment statements or assignment expressions can be used, prefer statements; they are a clear declaration of intent.
- If using assignment expressions would lead to ambiguity about execution order, restructure it to use statements instead.
The authors wish to thank Alyssa Coghlan and Steven D’Aprano for their considerable contributions to this proposal, and members of the core-mentorship mailing list for assistance with implementation.
Appendix A: Tim Peters’s findings
Here’s a brief essay Tim Peters wrote on the topic.
I dislike “busy” lines of code, and also dislike putting conceptually unrelated logic on a single line. So, for example, instead of:
instead. So I suspected I’d find few places I’d want to use assignment expressions. I didn’t even consider them for lines already stretching halfway across the screen. In other cases, “unrelated” ruled:
is a vast improvement over the briefer:
The original two statements are doing entirely different conceptual things, and slamming them together is conceptually insane.
In other cases, combining related logic made it harder to understand, such as rewriting:
as the briefer:
The while test there is too subtle, crucially relying on strict left-to-right evaluation in a non-short-circuiting or method-chaining context. My brain isn’t wired that way.
But cases like that were rare. Name binding is very frequent, and “sparse is better than dense” does not mean “almost empty is better than sparse”. For example, I have many functions that return None or 0 to communicate “I have nothing useful to return in this case, but since that’s expected often I’m not going to annoy you with an exception”. This is essentially the same as regular expression search functions returning None when there is no match. So there was lots of code of the form:
I find that clearer, and certainly a bit less typing and pattern-matching reading, as:
It’s also nice to trade away a small amount of horizontal whitespace to get another _line_ of surrounding code on screen. I didn’t give much weight to this at first, but it was so very frequent it added up, and I soon enough became annoyed that I couldn’t actually run the briefer code. That surprised me!
There are other cases where assignment expressions really shine. Rather than pick another from my code, Kirill Balunov gave a lovely example from the standard library’s copy() function in copy.py :
The ever-increasing indentation is semantically misleading: the logic is conceptually flat, “the first test that succeeds wins”:
Using easy assignment expressions allows the visual structure of the code to emphasize the conceptual flatness of the logic; ever-increasing indentation obscured it.
A smaller example from my code delighted me, both allowing to put inherently related logic in a single line, and allowing to remove an annoying “artificial” indentation level:
That if is about as long as I want my lines to get, but remains easy to follow.
So, in all, in most lines binding a name, I wouldn’t use assignment expressions, but because that construct is so very frequent, that leaves many places I would. In most of the latter, I found a small win that adds up due to how often it occurs, and in the rest I found a moderate to major win. I’d certainly use it more often than ternary if , but significantly less often than augmented assignment.
I have another example that quite impressed me at the time.
Where all variables are positive integers, and a is at least as large as the n’th root of x, this algorithm returns the floor of the n’th root of x (and roughly doubling the number of accurate bits per iteration):
It’s not obvious why that works, but is no more obvious in the “loop and a half” form. It’s hard to prove correctness without building on the right insight (the “arithmetic mean - geometric mean inequality”), and knowing some non-trivial things about how nested floor functions behave. That is, the challenges are in the math, not really in the coding.
If you do know all that, then the assignment-expression form is easily read as “while the current guess is too large, get a smaller guess”, where the “too large?” test and the new guess share an expensive sub-expression.
To my eyes, the original form is harder to understand:
This appendix attempts to clarify (though not specify) the rules when a target occurs in a comprehension or in a generator expression. For a number of illustrative examples we show the original code, containing a comprehension, and the translation, where the comprehension has been replaced by an equivalent generator function plus some scaffolding.
Since [x for ...] is equivalent to list(x for ...) these examples all use list comprehensions without loss of generality. And since these examples are meant to clarify edge cases of the rules, they aren’t trying to look like real code.
Note: comprehensions are already implemented via synthesizing nested generator functions like those in this appendix. The new part is adding appropriate declarations to establish the intended scope of assignment expression targets (the same scope they resolve to as if the assignment were performed in the block containing the outermost comprehension). For type inference purposes, these illustrative expansions do not imply that assignment expression targets are always Optional (but they do indicate the target binding scope).
Let’s start with a reminder of what code is generated for a generator expression without assignment expression.
- Original code (EXPR usually references VAR): def f (): a = [ EXPR for VAR in ITERABLE ]
- Translation (let’s not worry about name conflicts): def f (): def genexpr ( iterator ): for VAR in iterator : yield EXPR a = list ( genexpr ( iter ( ITERABLE )))
Let’s add a simple assignment expression.
- Original code: def f (): a = [ TARGET := EXPR for VAR in ITERABLE ]
- Translation: def f (): if False : TARGET = None # Dead code to ensure TARGET is a local variable def genexpr ( iterator ): nonlocal TARGET for VAR in iterator : TARGET = EXPR yield TARGET a = list ( genexpr ( iter ( ITERABLE )))
Let’s add a global TARGET declaration in f() .
- Original code: def f (): global TARGET a = [ TARGET := EXPR for VAR in ITERABLE ]
- Translation: def f (): global TARGET def genexpr ( iterator ): global TARGET for VAR in iterator : TARGET = EXPR yield TARGET a = list ( genexpr ( iter ( ITERABLE )))
Or instead let’s add a nonlocal TARGET declaration in f() .
- Original code: def g (): TARGET = ... def f (): nonlocal TARGET a = [ TARGET := EXPR for VAR in ITERABLE ]
- Translation: def g (): TARGET = ... def f (): nonlocal TARGET def genexpr ( iterator ): nonlocal TARGET for VAR in iterator : TARGET = EXPR yield TARGET a = list ( genexpr ( iter ( ITERABLE )))
Finally, let’s nest two comprehensions.
- Original code: def f (): a = [[ TARGET := i for i in range ( 3 )] for j in range ( 2 )] # I.e., a = [[0, 1, 2], [0, 1, 2]] print ( TARGET ) # prints 2
- Translation: def f (): if False : TARGET = None def outer_genexpr ( outer_iterator ): nonlocal TARGET def inner_generator ( inner_iterator ): nonlocal TARGET for i in inner_iterator : TARGET = i yield i for j in outer_iterator : yield list ( inner_generator ( range ( 3 ))) a = list ( outer_genexpr ( range ( 2 ))) print ( TARGET )
Because it has been a point of confusion, note that nothing about Python’s scoping semantics is changed. Function-local scopes continue to be resolved at compile time, and to have indefinite temporal extent at run time (“full closures”). Example:
This document has been placed in the public domain.
Source: https://github.com/python/peps/blob/main/peps/pep-0572.rst
Last modified: 2023-10-11 12:05:51 GMT
Welcome! This site is currently in beta. Get 10% off everything with promo code BETA10.
Python Assignment Operator
- Introduction
Chained Assignment
Shorthand assignment, shorthand assignment operators, playground: assignment operator practice, assignment methods.
All assignment operators are used to assign values to variables. Wait, is there more than one assignment operator? Yes, but they're all quite similar to the ones you've seen. You've used the most common assignment operator, and its symbol is a single equals sign ( = ).
For example, to assign x the value of 10 you type the following:
Different Assignment Methods
You have used this assignment statement before to assign values to variables. Apart from this very common way of using it, a few other situations use the same symbol for slightly different assignments.
You can assign the same value to multiple variables in one swoop by using an assignment chain:
This construct assigns 10 to x , y , and z . Using the chained assignment statement in Python is rare, but if you see it around, now you know what that's about.
Shorthand assignments, on the other hand, are a common occurrence in Python code. This is where the other assignment operators come into play. Shorthand assignments make writing code more efficient and can improve readability---at least once you know about them!
For example, think of a situation where you have a variable x and you want to add 1 to that variable:
This works well and is perfectly fine Python code. However, there is a more concise way of writing the same code using shorthand assignment :
Check out how the second line in these two code snippets is different. You don't need to write the name of the variable x a second time using the shorthand operator += like in the example above.
Both code examples shown achieve the exact same result and are equivalent. The shorthand assignment allows you to use less code to complete the task.
Python comes with a couple of shorthand assignment operators. Some of the most common ones include the following:
Operator | Meaning |
---|---|
+= | Add the value on the right to the variable on the left |
-= | Subtract the value on the right from the variable on the left |
*= | Multiply with the variable on the right, and add to the result on the left |
/= | Divide by the variable on the right, and add to the result on the left |
These operators are combinations of familiar arithmetic operators with the assignment operator ( = ). You have already used some of Python's arithmetic operators, and you'll learn more about them in the upcoming lesson.
Play around and combine different operators you can think of with the assignment operator below.
- Which ones work and do what you expect them to?
- Which ones don't?
Summary: Python Assignment Operator
- Assignment operators are used to assign values to variables
- Shorthand assignment is the most commonly used in Python
- The table summarizing the assignment operators is provided in the lesson
- Chain Assignment : A method used to assign multiple variables at one
- Shorthand Assignment : A series of short forms for manipulating data
PrepBytes Blog
ONE-STOP RESOURCE FOR EVERYTHING RELATED TO CODING
Sign in to your account
Forgot your password?
Login via OTP
We will send you an one time password on your mobile number
An OTP has been sent to your mobile number please verify it below
Register with PrepBytes
Assignment operator in python.
Last Updated on June 8, 2023 by Prepbytes
To fully comprehend the assignment operators in Python, it is important to have a basic understanding of what operators are. Operators are utilized to carry out a variety of operations, including mathematical, bitwise, and logical operations, among others, by connecting operands. Operands are the values that are acted upon by operators. In Python, the assignment operator is used to assign a value to a variable. The assignment operator is represented by the equals sign (=), and it is the most commonly used operator in Python. In this article, we will explore the assignment operator in Python, how it works, and its different types.
What is an Assignment Operator in Python?
The assignment operator in Python is used to assign a value to a variable. The assignment operator is represented by the equals sign (=), and it is used to assign a value to a variable. When an assignment operator is used, the value on the right-hand side is assigned to the variable on the left-hand side. This is a fundamental operation in programming, as it allows developers to store data in variables that can be used throughout their code.
For example, consider the following line of code:
Explanation: In this case, the value 10 is assigned to the variable a using the assignment operator. The variable a now holds the value 10, and this value can be used in other parts of the code. This simple example illustrates the basic usage and importance of assignment operators in Python programming.
Types of Assignment Operator in Python
There are several types of assignment operator in Python that are used to perform different operations. Let’s explore each type of assignment operator in Python in detail with the help of some code examples.
1. Simple Assignment Operator (=)
The simple assignment operator is the most commonly used operator in Python. It is used to assign a value to a variable. The syntax for the simple assignment operator is:
Here, the value on the right-hand side of the equals sign is assigned to the variable on the left-hand side. For example
Explanation: In this case, the value 25 is assigned to the variable a using the simple assignment operator. The variable a now holds the value 25.
2. Addition Assignment Operator (+=)
The addition assignment operator is used to add a value to a variable and store the result in the same variable. The syntax for the addition assignment operator is:
Here, the value on the right-hand side is added to the variable on the left-hand side, and the result is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is incremented by 5 using the addition assignment operator. The result, 15, is then printed to the console.
3. Subtraction Assignment Operator (-=)
The subtraction assignment operator is used to subtract a value from a variable and store the result in the same variable. The syntax for the subtraction assignment operator is
Here, the value on the right-hand side is subtracted from the variable on the left-hand side, and the result is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is decremented by 5 using the subtraction assignment operator. The result, 5, is then printed to the console.
4. Multiplication Assignment Operator (*=)
The multiplication assignment operator is used to multiply a variable by a value and store the result in the same variable. The syntax for the multiplication assignment operator is:
Here, the value on the right-hand side is multiplied by the variable on the left-hand side, and the result is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is multiplied by 5 using the multiplication assignment operator. The result, 50, is then printed to the console.
5. Division Assignment Operator (/=)
The division assignment operator is used to divide a variable by a value and store the result in the same variable. The syntax for the division assignment operator is:
Here, the variable on the left-hand side is divided by the value on the right-hand side, and the result is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is divided by 5 using the division assignment operator. The result, 2.0, is then printed to the console.
6. Modulus Assignment Operator (%=)
The modulus assignment operator is used to find the remainder of the division of a variable by a value and store the result in the same variable. The syntax for the modulus assignment operator is
Here, the variable on the left-hand side is divided by the value on the right-hand side, and the remainder is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is divided by 3 using the modulus assignment operator. The remainder, 1, is then printed to the console.
7. Floor Division Assignment Operator (//=)
The floor division assignment operator is used to divide a variable by a value and round the result down to the nearest integer, and store the result in the same variable. The syntax for the floor division assignment operator is:
Here, the variable on the left-hand side is divided by the value on the right-hand side, and the result is rounded down to the nearest integer. The rounded result is then stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is divided by 3 using the floor division assignment operator. The result, 3, is then printed to the console.
8. Exponentiation Assignment Operator (**=)
The exponentiation assignment operator is used to raise a variable to the power of a value and store the result in the same variable. The syntax for the exponentiation assignment operator is:
Here, the variable on the left-hand side is raised to the power of the value on the right-hand side, and the result is stored back in the variable on the left-hand side. For example
Explanation: In this case, the value of a is raised to the power of 3 using the exponentiation assignment operator. The result, 8, is then printed to the console.
9. Bitwise AND Assignment Operator (&=)
The bitwise AND assignment operator is used to perform a bitwise AND operation on the binary representation of a variable and a value, and store the result in the same variable. The syntax for the bitwise AND assignment operator is:
Here, the variable on the left-hand side is ANDed with the value on the right-hand side using the bitwise AND operator, and the result is stored back in the variable on the left-hand side. For example,
Explanation: In this case, the value of a is ANDed with 3 using the bitwise AND assignment operator. The result, 2, is then printed to the console.
10. Bitwise OR Assignment Operator (|=)
The bitwise OR assignment operator is used to perform a bitwise OR operation on the binary representation of a variable and a value, and store the result in the same variable. The syntax for the bitwise OR assignment operator is:
Here, the variable on the left-hand side is ORed with the value on the right-hand side using the bitwise OR operator, and the result is stored back in the variable on the left-hand side. For example,
Explanation: In this case, the value of a is ORed with 3 using the bitwise OR assignment operator. The result, 7, is then printed to the console.
11. Bitwise XOR Assignment Operator (^=)
The bitwise XOR assignment operator is used to perform a bitwise XOR operation on the binary representation of a variable and a value, and store the result in the same variable. The syntax for the bitwise XOR assignment operator is:
Here, the variable on the left-hand side is XORed with the value on the right-hand side using the bitwise XOR operator, and the result are stored back in the variable on the left-hand side. For example,
Explanation: In this case, the value of a is XORed with 3 using the bitwise XOR assignment operator. The result, 5, is then printed to the console.
12. Bitwise Right Shift Assignment Operator (>>=)
The bitwise right shift assignment operator is used to shift the bits of a variable to the right by a specified number of positions, and store the result in the same variable. The syntax for the bitwise right shift assignment operator is:
Here, the variable on the left-hand side has its bits shifted to the right by the number of positions specified by the value on the right-hand side, and the result is stored back in the variable on the left-hand side. For example,
Explanation: In this case, the value of a is shifted 2 positions to the right using the bitwise right shift assignment operator. The result, 2, is then printed to the console.
13. Bitwise Left Shift Assignment Operator (<<=)
The bitwise left shift assignment operator is used to shift the bits of a variable to the left by a specified number of positions, and store the result in the same variable. The syntax for the bitwise left shift assignment operator is:
Here, the variable on the left-hand side has its bits shifted to the left by the number of positions specified by the value on the right-hand side, and the result is stored back in the variable on the left-hand side. For example,
Conclusion Assignment operator in Python is used to assign values to variables, and it comes in different types. The simple assignment operator (=) assigns a value to a variable. The augmented assignment operators (+=, -=, *=, /=, %=, &=, |=, ^=, >>=, <<=) perform a specified operation and assign the result to the same variable in one step. The modulus assignment operator (%) calculates the remainder of a division operation and assigns the result to the same variable. The bitwise assignment operators (&=, |=, ^=, >>=, <<=) perform bitwise operations and assign the result to the same variable. The bitwise right shift assignment operator (>>=) shifts the bits of a variable to the right by a specified number of positions and stores the result in the same variable. The bitwise left shift assignment operator (<<=) shifts the bits of a variable to the left by a specified number of positions and stores the result in the same variable. These operators are useful in simplifying and shortening code that involves assigning and manipulating values in a single step.
Here are some Frequently Asked Questions on Assignment Operator in Python:
Q1 – Can I use the assignment operator to assign multiple values to multiple variables at once? Ans – Yes, you can use the assignment operator to assign multiple values to multiple variables at once, separated by commas. For example, "x, y, z = 1, 2, 3" would assign the value 1 to x, 2 to y, and 3 to z.
Q2 – Is it possible to chain assignment operators in Python? Ans – Yes, you can chain assignment operators in Python to perform multiple operations in one line of code. For example, "x = y = z = 1" would assign the value 1 to all three variables.
Q3 – How do I perform a conditional assignment in Python? Ans – To perform a conditional assignment in Python, you can use the ternary operator. For example, "x = a (if a > b) else b" would assign the value of a to x if a is greater than b, otherwise it would assign the value of b to x.
Q4 – What happens if I use an undefined variable in an assignment operation in Python? Ans – If you use an undefined variable in an assignment operation in Python, you will get a NameError. Make sure you have defined the variable before trying to assign a value to it.
Q5 – Can I use assignment operators with non-numeric data types in Python? Ans – Yes, you can use assignment operators with non-numeric data types in Python, such as strings or lists. For example, "my_list += [4, 5, 6]" would append the values 4, 5, and 6 to the end of the list named my_list.
Leave a Reply Cancel reply
Your email address will not be published. Required fields are marked *
Save my name, email, and website in this browser for the next time I comment.
- Linked List
- Segment Tree
- Backtracking
- Dynamic Programming
- Greedy Algorithm
- Operating System
- Company Placement
- Interview Tips
- General Interview Questions
- Data Structure
- Other Topics
- Computational Geometry
- Game Theory
Related Post
Python list functions & python list methods, python interview questions, namespaces and scope in python, what is the difference between append and extend in python, python program to check for the perfect square, python program to find the sum of first n natural numbers.
Currently Reading :
Currently reading:
Simple assignment operator in Python
Different assignment operators in python.
Rajat Gupta
Software Developer
Published on Thu Jun 30 2022
Assignment operators in Python are in-fix which are used to perform operations on variables or operands and assign values to the operand on the left side of the operator. They perform arithmetic, logical, and bitwise computations.
Assignment Operators in Python
Add and equal operator, subtract and equal operator, multiply and equal operator, divide and equal operator, modulus and equal operator, double divide and equal operator, exponent assign operator.
- Bitwise and operator
Bitwise OR operator
- Bitwise XOR Assignment operator
Bitwise right shift assignment operator
Bitwise left shift assignment operator.
The Simple assignment operator in Python is denoted by = and is used to assign values from the right side of the operator to the value on the left side.
This operator adds the value on the right side to the value on the left side and stores the result in the operand on the left side.
This operator subtracts the value on the right side from the value on the left side and stores the result in the operand on the left side.
The Multiply and equal operator multiplies the right operand with the left operand and then stores the result in the left operand.
It divides the left operand with the right operand and then stores the quotient in the left operand.
The modulus and equal operator finds the modulus from the left and right operand and stores the final result in the left operand.
The double divide and equal or the divide floor and equal operator divides the left operand with the right operand and stores the floor result in the left operand.
It performs exponential or power calculation and assigns value to the left operand.
Bitwise And operator
Performs Bitwise And operation on both variables and stores the result in the left operand. The Bitwise And operation compares the corresponding bits of the left operand to the bits of the right operand and if both bits are 1, the corresponding result is also 1 otherwise 0.
The binary value of 3 is 0011 and the binary value of 5 is 0101, so when the Bitwise And operation is performed on both the values, we get 0001, which is 1 in decimal.
Performs Bitwise OR operator on both variables and stores the result in the left operand. The Bitwise OR operation compares the corresponding bits of the left operand to the bits of the right operand and if any one of the bits is 1, the corresponding result is also 1 otherwise 0.
The binary value of 5 is 0101 and the binary value of 10 is 1010, so when the Bitwise OR operation is performed on both the values, we get 1111, which is 15 in decimal .
Bitwise XOR operator
Performs Bitwise XOR operator on both variables and stores the result in the left operand. The Bitwise XOR operation compares the corresponding bits of the left operand to the bits of the right operand and if only one of the bits is 1, the corresponding result is also 1 otherwise 0.
The binary value of 5 is 0101 and the binary value of 9 is 1001, so when the Bitwise XOR operation is performed on both the values, we get 1100, which is 12 in decimal.
This operator performs a Bitwise right shift on the operands and stores the result in the left operand.
The binary value of 15 is 1111, so when the Bitwise right shift operation is performed on ‘a’, we get 0011, which is 3 in decimal.
This operator performs a Bitwise left shift on the operands and stores the result in the left operand.
The binary value of 15 is 1111, so when the Bitwise left shift operation is performed on ‘a’, we get 11110, which is 30 in decimal.
Closing Thoughts
In this tutorial, we read about different types of assignment operators in Python which are special symbols used to perform arithmetic, logical, and bitwise operations on the operands and store the result in the left side operand. One can read about other Python concepts here .
Related Blogs
4 Ways to implement Python Switch Case Statement
Sanchitee Ladole
Converting String to Float in Python
Ancil Eric D'Silva
Memoization Using Decorators In Python
Harsh Pandey
Python Increment - Everything you need to know
Theano Python Beginner Guide for Getting Started
Taygun Dogan
17 min read
Python Classes And Objects
Browse Flexiple's talent pool
Explore our network of top tech talent. Find the perfect match for your dream team.
- Programmers
- React Native
- Ruby on Rails
Table of Contents
Assignment operator, addition assignment operator, subtraction assignment operator, multiplication assignment operator, division assignment operator, modulus assignment operator, floor division assignment operator, exponentiation assignment operator, bitwise and assignment operator, bitwise or assignment operator, bitwise xor assignment operator , bitwise right shift assignment operator, bitwise left shift assignment operator, walrus operator, conclusion , python assignment operator: tips and tricks to learn.
Assignment operators are vital in computer programming because they assign values to variables. Python stores and manipulates data with assignment operators like many other programming languages . First, let's review the fundamentals of Python assignment operators so you can understand the concept.
In Python, the following operators are often used for assignments:
Sign Type of Python Operators = Assignment Operator += Addition assignment -= Subtraction assignment *= Multiplication assignment /= Division assignment %= Modulus assignment //= Floor division assignment **= Exponentiation assignment &= Bitwise AND assignment |= Bitwise OR assignment ^= Bitwise XOR assignment >>= Bitwise right shift assignment <<= Bitwise left shift assignment := Walrus Operator
Python uses in-fix assignment operators to perform operations on variables or operands and assign values to the operand on the left side of the operator. It carries out calculations involving arithmetic, logical, and bitwise operations.
Python assignment operator provides a way to define assignment statements. This statement allows you to create, initialize, and update variables throughout your code, just like a software engineer . Variables are crucial in any code; assignment statements provide complete control over creating and modifying variables.
Understanding the Python assignment operator and how it is used in assignment statements can equip you with valuable tools to enhance the quality and reliability of your Python code.
In Python, the equals sign (=) is the primary assignment operator. It assigns the variable's value on the left side to the value on the right side of the operator.
Here's a sample to think about:
In this code snippet, the variable 'x' is given the value of 6. The assignment operator doesn't check for equality but assigns the value.
Become a Online Certifications Professional
- 13 % CAGR Estimated Growth By 2026
- 30 % Increase In Job Demand
Python Training
- 24x7 learner assistance and support
Automation Testing Masters Program
- Comprehensive blended learning program
- 200 hours of Applied Learning
Here's what learners are saying regarding our programs:
Charlotte Martinez
This is a good course for beginners as well as experts with all the basic concepts explained clearly. It's a good starter to move to python programming for programmers as well as non- programmers
Daniel Altufaili
It infrastructure oprations , johnson electric.
Upon finishing the QA automation course, I received fresh assignments at my job owing to my heightened proficiency in IT, IoT, and ML. In addition to this, I earned a promotion and 20% salary increase. This course significantly expanded my expertise and motivated me to continuously enhance my skills through ongoing upskilling efforts.
The addition assignment operator (+=) adds the right-hand value to the left-hand variable.
The addition assignment operator syntax is variable += value.
The addition assignment operator increments a by 5. The console displays 14 as the result.
Also Read: Top Practical Applications of Python
The subtraction assignment operator subtracts a value from a variable and stores it in the same variable.
The subtraction assignment operator syntax is variable-=-value.
Using the multiplication assignment operator (=), multiply the value on the right by the variable's existing value on the left.
The assignment operator for multiplication has the following syntax: variable *= value
In this situation, the multiplication assignment operator multiplies the value of a by 2. The output, 10, is shown on the console.
Related Read: 16 Most Important Python Features and How to Use them
Using the division assignment operator (/=), divide the value of the left-hand variable by the value of the right-hand variable.
The assignment operator for division has the following syntax: variable /= value
Using the division assignment operator, divide a value by 3. The console displays 5.0.
Recommended Read: Why Choose Python? Discover Its Core Advantages!
The modulus assignment operator (% =) divides the left and right variable values by the modulus. The variable receives the remainder.
The modulus assignment operator syntax is variable %= value.
The modulus assignment operator divides a by 2. The console displays the following: 1.
Use "//" to divide and assign floors in one phrase. What "a//=b" means is "a=a//b". This operator cannot handle complicated numbers.
The floor division assignment operator syntax is variable == value.
The floor division assignment operator divides a by 2. The console displays 5.
The exponentiation assignment operator (=) elevates the left variable value to the right value's power.
Operator syntax for exponentiation assignment:
variable**=value
The exponentiation assignment operator raises a to 2. The console shows 9.
The bitwise AND assignment operator (&=) combines the left and right variable values using a bitwise AND operation. Results are assigned to variables.
The bitwise AND assignment operator syntax is variable &= value.
The bitwise AND assignment operator ANDes a with 2. The console displays 2 as the outcome.
The bitwise OR assignment operator (|=) bitwise ORs the left and right variable values.
The bitwise OR assignment operator syntax is variable == value.
A is ORed with 4 using the bitwise OR assignment operator. The console displays 6.
Use the bitwise XOR assignment operator (^=) to XOR the left and right values of a variable. Results are assigned to variables.
For bitwise XOR assignment, use the syntax: variable ^= value.
The bitwise XOR assignment operator XORs a with 4. The console displays 2 as the outcome.
The right shift assignment operator (>>=) shifts the variable's left value right by the number of places specified on the right.
The assignment operator for the bitwise right shift has the following syntax:
variable >>= value
The bitwise right shift assignment operator shifts 2 places to the right. The result is 1.
The variable value on the left moves left by the specified number of places on the right using the left shift assignment operator (<<=).
The bitwise left shift assignment operator syntax is variable <<= value.
When we execute a Bitwise right shift on 'a', we get 00011110, which is 30 in decimal.
Python gets new features with each update. Emily Morehouse added the walrus operator to Python 3.8's initial alpha. The most significant change in Python 3.8 is assignment expressions. The ":=" operator allows mid-expression variable assignment. This operator is called the walrus operator.
variable := expression
It was named for the operator symbol (:=), which resembled a sideways walrus' eyes and tusks.
Walrus operators simplify code authoring, which is its main benefit. Each user input was stored in a variable before being passed to the for loop to check its value or apply a condition. It is important to note that the walrus operator cannot be used alone.
With the walrus operator, you can simultaneously define a variable and return a value.
Above, we created two variables, myVar and value, with the phrase myVar = (value = 2346). The expression (value = 2346) defines the variable value using the walrus operator. It returns the value outside the parenthesis as if value = 2346 were a function.
The variable myVar is initialized using the return value from the expression (value = 2346).
The output shows that both variables have the same value.
Learn more about other Python operators by reading our detailed guide here .
Discover how Python assignment operators simplify and optimize programs. Python assignment operators are explained in length in this guide, along with examples, to help you understand them. Start this intriguing journey to improve your Python knowledge and programming skills with Simplilearn's Python training course .
1. What is the ":=" operator in Python?
Python's walrus operator ":" evaluates, assigns, and returns a value from a single sentence. Python 3.8 introduces it with this syntax (variable:=expression).
2. What does = mean in Python?
The most significant change in Python 3.8 is assignment expressions. The walrus operator allows mid-expression variable assignment.
3. What is def (:) Python?
The function definition in Python is (:). Functions are defined with def. A parameter or parameter(s) follows the function name. The function body begins with an indentation after the colon (:). The function body's return statement determines the value.
Our Software Development Courses Duration And Fees
Software Development Course typically range from a few weeks to several months, with fees varying based on program and institution.
Program Name | Duration | Fees |
---|---|---|
Cohort Starts: | 4 Months | € 2,499 |
Cohort Starts: | 6 Months | € 1,500 |
Cohort Starts: | 6 Months | € 1,500 |
Cohort Starts: | 11 Months | € 1,099 |
Recommended Reads
Python Interview Guide
Filter in Python
Understanding Python If-Else Statement
Top Job Roles in the Field of Data Science
Yield in Python: An Ultimate Tutorial on Yield Keyword in Python
The Best Tips for Learning Python
Get Affiliated Certifications with Live Class programs
- PMP, PMI, PMBOK, CAPM, PgMP, PfMP, ACP, PBA, RMP, SP, and OPM3 are registered marks of the Project Management Institute, Inc.
- School Guide
- Class 11 Syllabus
- Class 11 Revision Notes
- Maths Notes Class 11
- Physics Notes Class 11
- Chemistry Notes Class 11
- Biology Notes Class 11
- NCERT Solutions Class 11 Maths
- RD Sharma Solutions Class 11
- Math Formulas Class 11
Augmented Assignment Operators in Python
An assignment operator is an operator that is used to assign some value to a variable. Like normally in Python, we write “ a = 5 “ to assign value 5 to variable ‘a’. Augmented assignment operators have a special role to play in Python programming. It basically combines the functioning of the arithmetic or bitwise operator with the assignment operator. So assume if we need to add 7 to a variable “a” and assign the result back to “a”, then instead of writing normally as “ a = a + 7 “, we can use the augmented assignment operator and write the expression as “ a += 7 “. Here += has combined the functionality of arithmetic addition and assignment.
So, augmented assignment operators provide a short way to perform a binary operation and assigning results back to one of the operands. The way to write an augmented operator is just to write that binary operator and assignment operator together. In Python, we have several different augmented assignment operators like +=, -=, *=, /=, //=, **=, |=, &=, >>=, <<=, %= and ^=. Let’s see their functioning with the help of some exemplar codes:
1. Addition and Assignment (+=): This operator combines the impact of arithmetic addition and assignment. Here,
a = a + b can be written as a += b
2. Subtraction and Assignment (-=): This operator combines the impact of subtraction and assignment.
a = a – b can be written as a -= b
Example:
3. Multiplication and Assignment (*=): This operator combines the functionality of multiplication and assignment.
a = a * b can be written as a *= b
4. Division and Assignment (/=): This operator has the combined functionality of division and assignment.
a = a / b can be written as a /= b
5. Floor Division and Assignment (//=): It performs the functioning of floor division and assignment.
a = a // b can be written as a //= b
6. Modulo and Assignment (%=): This operator combines the impact of the modulo operator and assignment.
a = a % b can be written as a %= b
7. Power and Assignment (**=): This operator is equivalent to the power and assignment operator together.
a = a**b can be written as a **= b
8. Bitwise AND & Assignment (&=): This operator combines the impact of the bitwise AND operator and assignment operator.
a = a & b can be written as a &= b
9. Bitwise OR and Assignment (|=): This operator combines the impact of Bitwise OR and assignment operator.
a = a | b can be written as a |= b
10. Bitwise XOR and Assignment (^=): This augmented assignment operator combines the functionality of the bitwise XOR operator and assignment operator.
a = a ^ b can be written as a ^= b
11. Bitwise Left Shift and Assignment (<<=): It puts together the functioning of the bitwise left shift operator and assignment operator.
a = a << b can be written as a <<= b
12. Bitwise Right Shift and Assignment (>>=): It puts together the functioning of the bitwise right shift operator and assignment operator.
a = a >> b can be written as a >>= b
Please Login to comment...
Similar reads.
- School Learning
- School Programming
Improve your Coding Skills with Practice
What kind of Experience do you want to share?
What is Assignment Operator in Python?
Before deep-diving into the assignment operators in Python, first, understand what operators are. So operators are used in between the operands to perform various operations, like mathematical operations , bitwise operations , logical operations , and so on. Here, operands are the values on which operators perform the actions. So, assignment operators are used to assigning values to the operands on the left-hand side. Assignment operators assign the right-hand side values to the operand that is present on the left-hand side. The assignment operator in Python is used as the "=" symbol.
Let’s see a very basic example of the assignment operator.
Table Of Assignment Operators
Here we will see different assignment operators in Python with their names, descriptions, and syntax. Let's take them one by one.
Operator | Name | Description | Syntax |
---|---|---|---|
Assignment Operator | It assigns the right-hand side expression value to the operand present on the left-hand side. | a=b+c | |
Addition Assignment Operator | This operator adds left and right operands, and after that, it assigns the calculated value to the left-hand operand. | a+=b or a=a+b | |
Subtraction Assignment Operator | This operator subtracts the right operand from the left operand and assigns the result to the left operand. | a-=b or a=a-b | |
Multiplication Assignment Operator | This operator will multiply the left-hand side operand by the right-hand side operand and, after that, assign the result to the left-hand operand. | a*=b or a=a*b | |
Division Assignment Operator | This operator will divide the left-hand side operand by the right-hand side operand and, after that, assign the result to the left-hand operand. | a/=b or a=a/b | |
Modulus Assignment Operator | This operator will divide the left-hand side operand by the right-hand side operand and, after that, assign the reminder to the left-hand operand. | a%=b or a=a%b | |
Exponentiation Assignment Operator | This operator raises the left-side operand to the power of the right-side operand and assigns the result to the left-side value. | a**=b or a=a**b | |
Floor Division Assignment Operator | This operator will divide the left operand by the right operand and assign the quotient value (which would be in the form of an integer) to the left operand. | a//=b or a=a//b | |
Bitwise AND Assignment Operator | This operator will perform the bitwise operation on both the left and right operands and, after that, it will assign the resultant value to the left operand. | a&=b or a=a&b | |
Bitwise OR Assignment Operator | This operator will perform the bitwise or operation on both the left and right operands and, after that, it will assign the resultant value to the left operand. | a|=b or a=a|b | |
Bitwise XOR Assignment Operator | This operator will perform the bitwise XOR operation on the left and right operands and, after that, it will assign the resultant value to the left operand. | a^=b or a=a^b | |
Bitwise Right Shift Assignment Operator | This operator will right-shift the left operand by the specified position, i.e., b, and after that, it will assign the resultant value to the left operand. | a>>=b or a=a>>b | |
Bitwise Left Shift Assignment Operator | This operator will left shift the left operand by the specified position, i.e., b, and after that, it will assign the resultant value to the left operand. | a<<=b or a=a<<b |
Assignment Operator :
This is an assignment operator in Python which assigns the right-hand side expression value to the operand present on the left-hand side.
Sample Code :
Addition Assignment Operator :
This type of assignment operator in Python adds left and right operands, and after that, it assigns the calculated value to the left-hand operand.
Subtraction Assignment Operator :
This operator subtracts the right operand from the left operand and assigns the result to the left operand.
Multiplication Assignment Operator:
This operator will multiply the left-hand side operand by the right-hand side operand and, after that, assign the result to the left-hand operand.
Division Assignment Operator :
This type of assignment operator in Python will divide the left-hand side operand from the right-hand side operand and, after that, assign the result to the left-hand operand.
Modulus Assignment Operator :
This operator will divide the left-hand side operand to the right-hand side operand and, after that, assign the reminder to the left-hand operand.
Click here, to learn more about modulus in python .
Exponentiation Assignment Operator :
This operator raises the left-side operand to the power of the right-side operand and assigns the result to the left-side value.
Floor Division Assignment Operator :
This operator will divide the left operand by the right operand and assign the quotient value (which would be in the form of an integer) to the left operand.
Bitwise AND Assignment Operator :
This operator will perform the bitwise operation on both the left and right operands and, after that, it will assign the resultant value to the left operand.
Bitwise OR Assignment Operator:
This operator will perform the bitwise or operation on both the left and right operands and, after that, it will assign the resultant value to the left operand.
Bitwise XOR Assignment Operator:
This operator will perform the bitwise XOR operation on the left and right operands and, after that, it will assign the resultant value to the left operand.
Bitwise Right Shift Assignment Operator :
This operator will right shift the left operand by the specified position, i.e., b , and after that, it will assign the resultant value to the left operand.
Bitwise Left Shift Assignment Operator:
This operator will left shift the left operand by the specified position, i.e., b , and after that, it will assign the resultant value to the left operand.
- Assignment operators in Python assign the right-hand side values to the operand that is present on the left-hand side.
- The assignment operators in Python is used as the "=" symbol.
- We have different types of assignment operators like +=, -=, \*=, %=, /=, //=, \*\*=, &=, |=, ^=, >>=, <<= .
- All the operators have the same precedence, and hence we prioritise operations based on their associativiy . The associativity is from right to left.
Learn More:
- XOR in Python .
With-Assignment statement
Related topics.
Topic | Replies | Views | Activity | |
---|---|---|---|---|
Ideas | 26 | 2239 | November 22, 2023 | |
Ideas | 5 | 727 | July 9, 2023 | |
Ideas | 3 | 733 | March 11, 2023 | |
Python Help | 16 | 238 | June 22, 2024 | |
Ideas | 18 | 475 | July 15, 2024 |
- Stack Overflow for Teams Where developers & technologists share private knowledge with coworkers
- Advertising & Talent Reach devs & technologists worldwide about your product, service or employer brand
- OverflowAI GenAI features for Teams
- OverflowAPI Train & fine-tune LLMs
- Labs The future of collective knowledge sharing
- About the company Visit the blog
Collectives™ on Stack Overflow
Find centralized, trusted content and collaborate around the technologies you use most.
Q&A for work
Connect and share knowledge within a single location that is structured and easy to search.
Get early access and see previews of new features.
What is the purpose of assignment operator used in conditional statements in JavaScript? [closed]
In python, conditional statements(If-else) takes only True/False in its expression field. i.e,
But, in JavaScript, conditional statements can take Assignment operator too. i.e,
My question is:- In Js, while using Assignment operator in Conditional statements, definitely it will become true. So, in that case, there is no need to use Conditional statements right? Instead we can write,
Is there any beneficial reason to use Assignment Operator in Conditional Statements?
- conditional-statements
- assignment-operator
- 1 just because your example is trivial, it doesn't mean the feature is useless. in python you have now the "walrus operator" := which is indeed very useful – folen gateis Commented yesterday
- 1 "definitely it will become true" - How did you get that idea? – no comment Commented yesterday
- Conditional statements can take the results of any expression in Python, not just boolean True/False. – notovny Commented yesterday
- in your second example, try let b = 0; ... the "assignment operator" as you call it is just shorthand for assigning a value AND checking it .. a less trivial (but still trivial) example could be if ((a = b) == c) { ... } - personally, I never use such code, since the days of 33kilobaud internet connections are long gone, so no more need for less readable brevity in your code - besides, code minifiers exist to minify easily readable development code to space saving production code – Jaromanda X Commented yesterday
Browse other questions tagged javascript python conditional-statements assignment-operator or ask your own question .
- Featured on Meta
- Upcoming initiatives on Stack Overflow and across the Stack Exchange network...
- Announcing a change to the data-dump process
Hot Network Questions
- Can one be restricted from carrying a gun on the metro in New York city?
- Factoriadic Fraction Addition
- How to overload / customize bash (or any other shell) commands handler?
- Seeking optimization modelling problems involving non-continuous or non-interval defined functions for teaching
- How do I drop a database which has brackets in its name?
- English equivalent for the idiom "mother-in-law has forgotten to wear her saree (dress)"
- Is a decision caused by a prior brain state?
- How can dragons breathe in space?
- N-MOS failing short on my PCB
- Can a "read-only" µSD card be salvaged?
- How to calculate baker's percentages for indirect doughs?
- Annihilator attack target is switched
- Short story where a scientist develops a virus that renders everyone on Earth sterile
- How to choose correct resistor values when designing a circuit?
- Tale of two servers. What could be limiting queries to running on two cores? MDOP set to 16
- Why did Kamala Harris once describe her own appearance at the start of an important meeting?
- Is "natural person" an idiomatic way to describe someone who's the opposite of pretentious?
- Is it ethical for a PI of a collaborating PhD student to be part of my publication?, even if he hasn't contributed anything
- Is there any point to the copyright notice in 0BSD?
- When labeling, "Wrap on character" drops the wrap character
- Probability of a Bernoulli r.v. conditioned on the sample proportion estimate of its parameter
- Travelling from Ireland to Northern Ireland (UK Visa required national)
- Publishing a paper written in your free time as an unaffiliated author when you are affiliated
- How to make an entire section as a conjecture?
IMAGES
VIDEO
COMMENTS
Here, variable represents a generic Python variable, while expression represents any Python object that you can provide as a concrete value—also known as a literal—or an expression that evaluates to a value. To execute an assignment statement like the above, Python runs the following steps: Evaluate the right-hand expression to produce a concrete value or object.
The Python Operators are used to perform operations on values and variables. These are the special symbols that carry out arithmetic, logical, and bitwise computations. The value the operator operates on is known as the Operand.
W3Schools offers free online tutorials, references and exercises in all the major languages of the web. Covering popular subjects like HTML, CSS, JavaScript, Python, SQL, Java, and many, many more.
For demonstration purposes, let's use a single variable, num.Initially, we set num to 6. We can apply all of these operators to num and update it accordingly.. Assignment. Assigning the value of 6 to num results in num being 6.. Expression: num = 6 Add and assign
Each new version of Python adds new features to the language. For Python 3.8, the biggest change is the addition of assignment expressions.Specifically, the := operator gives you a new syntax for assigning variables in the middle of expressions. This operator is colloquially known as the walrus operator.. This tutorial is an in-depth introduction to the walrus operator.
Learn how to use Python operators for arithmetic, assignment, comparison, logical, identity, membership, and bitwise operations with W3Schools.
Assignment Operators in Python are used to assign values to the variables. "=" is the fundamental Python assignment operator. The value on the right side of the "=" is assigned to the variable on the left side of "=". In this Python tutorial, we'll understand Python programming assignment operators with examples and augmented assignment operators in Python.
Python Assignment Operator. The = (equal to) symbol is defined as assignment operator in Python. The value of Python expression on its right is assigned to a single variable on its left. The = symbol as in programming in general (and Python in particular) should not be confused with its usage in Mathematics, where it states that the expressions on the either side of the symbol are equal.
Let's take a look at some examples. Operator Assignment (=) This is the most basic assignment operator and we used it before in the lessons about lists, tuples, and dictionaries.. For example, we can assign a value (integer) to a variable:
In this example, the variable x is assigned the value 5. There are also several compound assignment operators in Python, which are used to perform an operation and assign the result to a variable in a single step.
Operators are special symbols that perform some operation on operands and returns the result. For example, 5 + 6 is an expression where + is an operator that performs arithmetic add operation on numeric left operand 5 and the right side operand 6 and returns a sum of two operands as a result.
Python Assignment Operators Example. For this example, we are using four variables: a, Total, x, and y; their values are 7, 21, 9, and 65. Next, we use them to show the working functionality of all the Python Assignment Operators.
Assignment operators are a fundamental concept in Python and most programming languages. They are used to assign values to variables, as well as initialize and update them.
Assignment Operators Assignment Operator. Equal to sign '=' is used as an assignment operator. It assigns values of the right-hand side expression to the variable or operand present on the left-hand side.
This shows that what looks like an assignment operator in an f-string is not always an assignment operator. The f-string parser uses : to indicate formatting options. To preserve backwards compatibility, assignment operator usage inside of f-strings must be parenthesized.
Playground: Assignment Operator Practice. Play around and combine different operators you can think of with the assignment operator below. x = 3 x += 1 print(x)
Assignment operator in Python is used to assign values to variables, and it comes in different types. Let's explore each type of assignment operator in detail.
Assignment operators in Python are in-fix which are used to perform operations on variables or operands and assign values to the operand on the left side of the operator. They perform arithmetic, logical, and bitwise computations. Assignment Operators in Python. Simple assignment operator in Python
Since Python 3.8, code can use the so-called "walrus" operator (:=), documented in PEP 572, for assignment expressions.This seems like a really substantial new feature, since it allows this form of assignment within comprehensions and lambdas.. What exactly are the syntax, semantics, and grammar specifications of assignment expressions?
Assignment Operator Overview Python uses in-fix assignment operators to perform operations on variables or operands and assign values to the operand on the left side of the operator. It carries out calculations involving arithmetic, logical, and bitwise operations. Python assignment operator provides a way to define assignment statements.
An assignment operator is an operator that is used to assign some value to a variable. Like normally in Python, we write "a = 5" to assign value 5 to variable 'a'. Augmented assignment operators have a special role to play in Python programming.
Before deep-diving into the assignment operators in Python, first, understand what operators are. So operators are used in between the operands to perform various operations, like mathematical operations, bitwise operations, logical operations, and so on.Here, operands are the values on which operators perform the actions.
The way you describe it is absolutely not possible. Assignment to a name is a fundamental feature of Python and no hooks have been provided to change its behavior.
I agree. Should we resurrect Add pinned post in ideas? The main reason for its rejection was that the proposal was made by the person who himself was the problem trying to be solved. Maybe if we could re-shape, update, reformat, etc, we could push it through? Personally, I have already linked it at least a couple of times and thought about linking it few more times. @pf_moore @kknechtel, you ...
Stack Overflow for Teams Where developers & technologists share private knowledge with coworkers; Advertising & Talent Reach devs & technologists worldwide about your product, service or employer brand; OverflowAI GenAI features for Teams; OverflowAPI Train & fine-tune LLMs; Labs The future of collective knowledge sharing; About the company Visit the blog