# Python: Division

# Python: Division

In Python, there are two kinds of division: integer division and float division.

**Integer Division**

Integer division returns the floor of the division. That is, the values after the decimal point are discarded. It is written as '//' in Python 3. So, 1//3 = 0, 2//3 = 0 and 3//3 = 1. Integer values are precisely stored, so they are safe to use in comparisons.

In Python 2, the '//' operator is not included, so it must be imported from the `__future__`

module. See the code below for how to use the '//' operator in Python 2. The '/' operator in Python 2 returns an integer result if both of the operands are integers.

**Python 2**

```
# Python 2 integer division using '//'
from __future__ import division
print 4//3 # prints 1
```

or

```
# Python 2 integer division using '/'
print 4/3 # prints 1
```

**Python 3**

```
# Python 3 integer division
print(4//3) # prints 1
```

**Float Division**

Float division returns a floating point approximation of the result of a division. For example, . Only a certain number of values after the decimal can be stored, so it is not possible to store an exact binary representation of many floating point numbers. This sometimes leads to problems when comparing numbers or when rounding.

In Python 2, the only standard division operator is '/'. If both values are integers, the result is an integer. If either of the values is a float, the return is a float. The `__future__`

module can be used so that '/' represents floating point division as it does in Python 3.

**Python 2**

```
from __future__ import division
# floating point division using __future__ syntax
print 4 / 3 # prints 1.33333333333
```

or

```
# floating point division using a float to force float result
# no need to import from __future__
print 4 / 3.0 # prints 1.33333333333
```

**Python 3**

```
print(4 / 3) # prints 1.33333333333
```

See **__future__** for documentation of the module.