---
title: Python Comparisons
---
[Python Docs - Comparisons](https://docs.python.org/3/library/stdtypes.html#comparisons)
There are eight comparison operations in Python. They all have the same priority (which is higher than that of the Boolean operations). Comparisons can be chained arbitrarily; for example, `x < y <= z` is equivalent to `x < y and y <= z`, except that `y` is evaluated only once (but in both cases `z` is not evaluated at all when `x < y` is found to be false).
You can also give two condition and check for only one condition using `or`  like `x > y or x >= y` will check for either of the two conditions. If one of the condition is true the program will proceed. This is the functionality of `or`.
This table summarizes the comparison operations:
Operation | Meaning  
--------- | -----------------------  
`<` | strictly less than  
`<=` | less than or equal to 
`>` | strictly greater than 
`>=` | greater than or equal to
`==` | equal to 
`!=` | not equal to 
`is` | object identity  
`is not` | negated object identity
Objects of different types, except different numeric types, never compare equal. Furthermore, some types (for example, function objects) support only a degenerate notion of comparison where any two objects of that type are unequal. The `<`, `<=`, `>` and `>=` operators will raise a `TypeError` exception when comparing a complex number with another built-in numeric type, when the objects are of different types that cannot be compared, or in other cases where there is no defined ordering.
Non-identical instances of a class normally compare as non-equal unless the class defines the `__eq__()` method.
Instances of a class cannot be ordered with respect to other instances of the same class, or other types of object, unless the class defines enough of the methods `__lt__()`, `__le__()`, `__gt__()`, and `__ge__()` (in general, `__lt__()` and `__eq__()` are sufficient, if you want the conventional meanings of the comparison operators).
The behavior of the `is` and `is not` operators cannot be customized; also they can be applied to any two objects and never raise an exception.
We can also chain `<` and `>` operators together. For instance, `3 < 4 < 5` will return `True`, but `3 < 4 > 5` will not. We can also chain the equality operator. For instance, `3 == 3 < 5` will return `True` but `3 == 5 < 5` will not.
### Equality Comparisons - "is" vs "=="
In Python, there are two comparison operators which allow us to check to see if two objects are equal. The `is` operator and the `==` operator. However, there is a key difference between them!
The key difference between `is` and `==` can be summed up as:
* `is` is used to compare identity
* `==` is used to compare equality
## Example
First, create a list in Python.
```python
myListA = [1,2,3]
```
Next, create a copy of that list. 
```python
myListB = myListA
```
If we use the `==` operator or the `is` operator, both will result in a True output. 
```python
>>> myListA == myListB # both lists contains similar elements
True
>>> myListB is myListA # myListB contains the same elements
True
```
This is because both myListA and myListB are pointing to the same list variable, which I defined at beginning of my Python program. Both lists are exactly the same, both in identity and in content.
However, what if I now create a new list?
```python
myListC = [1,2,3]
```
Performing the `==` operator still shows that both lists are the same, in terms of content.
```python
>>> myListA == myListC
True
```
However, performing the `is` operator will now produce a `False` output. This is because myListA and myListC are two different variables, despite containing the same data. Even though they look the same, they are different.
```python
>>> myListA is myListC
False # both lists have different reference
```
To sum up:
* An `is` expression outputs `True` if both variables are pointing to the same reference 
* An `==` expression outputs `True` if both variables contain the same data
However, interestingly, there are a few special cases in Python with `is`.
```python
>>> a = 5
>>> b = 5
>>> a is b
True
>>> a = 1000
>>> b = 1000
>>> a is b
False
```
This is due to how Python is implemented. In Python, small integers (from -5 up to 256, a fast test shows) are cached. You shouldn't rely on this detail – larger integers do not evaluate to `true` when you use `is`. For more information on this topic, view this StackOverflow thread.