Python map() function

Updated on Jan 07, 2020


The map() built-in function returns an iterator after applying the function to each item in the sequence. Its syntax is as follows:

Syntax: map(function, sequence[, sequence, ...]) -> map object

Python 3

1
2
3
4
5
6
7
>>>
>>> map(ord, ['a', 'b', 'c', 'd'])
<map object at 0x7f36fac76dd8>
>>>
>>> list(map(ord, ['a', 'b', 'c', 'd']))
>>> [97, 98, 99, 100]
>>>
map_obj = map(ord, ['a', 'b', 'c', 'd'])
print(map_obj)
print(list(map_obj))


Here the items in the list are passed to the ord() built-in function one at a time.

Since map() returns an iterator, we have used the list() function to produce the result at once.

The preceding code is functionally equivalent to the following:

Python 3

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
>>>
>>> ascii = []
>>>
>>> for i in ['a', 'b', 'c', 'd']:
...   ascii.append(ord(i))
...
>>>
>>> ascii
[97, 98, 99, 100]
>>>
ascii = []

for i in ['a', 'b', 'c', 'd']:
    ascii.append(ord(i))

print(ascii)


However, using map() results in shorter code and is often run faster.

In Python 2, the map() function returns a list instead of an iterator (which is not very efficient in terms of memory consumption), so we don't need to wrap map() in a list() call.

Python 2

1
2
3
4
>>>
>>> map(ord, ['a', 'b', 'c', 'd']) # in Python 2
[97, 98, 99, 100]
>>>

Passing User-defined Function #


In the following listing, we are passing a user-defined function to the map() function.

Python 3

1
2
3
4
5
6
7
8
>>>
>>> def twice(x):
...     return x*2
...
>>>
>>> list(map(twice, [11,22,33,44,55]))
[22, 44, 66, 88, 110]
>>>
def twice(x):
    return x*2

print(list(map(twice, [11,22,33,44,55])))


Here, the function multiplies each item in the list by 2.

Passing Multiple Arguments #


If we pass n sequences to map(), the function must take n number of arguments and items from the sequences are consumed in parallel, until the shortest sequence is exhausted. In Python 2, however, the map() function stops when the longest sequence is exhausted and value of None is used as padding when the shorter sequence is exhausted.

Python 3

1
2
3
4
5
6
7
8
>>>
>>> def calc_sum(x1, x2):
...     return x1+x2
...
>>>
>>> list(map(calc_sum, [1, 2, 3, 4, 5], [10, 20, 30]))
[11, 22, 33]
>>>
def calc_sum(x1, x2):
    return x1+x2

map_obj = list(map(calc_sum, [1, 2, 3, 4, 5], [10, 20, 30]))
print(map_obj)


Python 2

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
>>>
>>> def foo(x1, x2):
...     if x2 is None:
...         return x1
...     else:
...         return x1+x2
...
>>>
>>> list(map(foo, [1, 2, 3, 4, 5], [10, 20, 30]))
[11, 22, 33, 4, 5]
>>>

Passing Lambda #


If your function doesn't mean to be reused you can pass a lambda (inline anonymous function) instead of a function.

Python 3

1
2
3
4
>>> 
>>> list(map(lambda x1:x1*5, [1, 2, 3]))
[5, 10, 15]
>>>
map_obj = map(lambda x1:x1*5, [1, 2, 3])
print(list(map_obj))


Here, the function multiples each item in the list by 5.

Pairing Items (Only in Python 2) #


Finally, you can pair items from multiple sequences by passing None in place of a function:

Python 2

1
2
3
4
>>> 
>>> map(None, "hello", "pi")
[('h', 'p'), ('e', 'i'), ('l', None), ('l', None), ('o', None)]
>>>

Notice that when the shorter sequence is exhausted None is used to pad the result.

This form of map() not valid in Python 3.

1
2
3
4
5
6
>>> 
>>> list(map(None, "hello", "pi"))
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
TypeError: 'NoneType' object is not callable
>>>
print(list(map(None, "hello", "pi")))


If you want to pair items from multiple sequences use the zip() function.


Other Tutorials (Sponsors)