Зачастую с map используются анонимные функции, как в примере выше. Вместо списка входных данных можно также использовать список функций!
defmultiply(x):return(x*x)defadd(x):return(x+x)funcs =[multiply, add]for i inrange(5): value =list(map(lambdax: x(i), funcs))print(value)# Вывод:# [0, 0]# [1, 2]# [4, 4]# [9, 6]# [16, 8]
Filter
Как можно догадаться по имени, filter возвращает список элементов, для которых заданная функция возвращает True. Вот простой и понятный пример:
filer уподобляется циклу, но он является встроенной функцией и работает быстрее.
Примечание: Если map и filter не кажутся вам достаточно красивым решением, то вы всегда можете использовать абстракции списков/словарей/кортежей. Использование последних считается хорошим тоном, так как практически во всех случаях улучшает читаемость без потери функционала.
Reduce
Reduce весьма полезная функция для выполнения вычислений на списке и возвращения единственного результата. Она сворачивает список, применяя полученную в качестве аргумента функцию по очереди к последовательным парам элементов. Например, если мы хотим посчитать произведение всех элементов списка чисел.
Обычным решением этой задачи будет использования цикла for: