一日一技:在Python中使用reduce

简介: 一日一技:在Python中使用reduce

在之前的一篇文章:【一日一技】Django不定项数的“或查询”里面,我们讲到,如果在Django的model中对多个查询条件使用 操作,那么代码可以这样写:

from django.db.models import Q
keywords = ['促销', '打折', '限时']
item = Product.objects
if keywords:
    filters = Q(description__contains=keywords[0])
    for keyword in keywords[1:]:
        filters |= Q(description__contains=keyword)
    item = item.filter(filters)

不过这样写代码并不好看,因为要先把第一个参数取出来单独生成一个查询对象。然后再用这个查询对象与后面的参数形成的查询对象取或操作。

对于这种从一个可迭代对象里面依次读取每一个元素,传入到一个函数中,生成的结果再依次与可迭代对象后面的数据进行相同的操作,我们可以使用 reduce

例如有一个函数 func,它接收两个参数,返回一个参数。现在我们有一个列表, [1,2,3,4,5],想实现:

a = [1, 2, 3, 4, 5]
data = func(a[0], a[1])
data_2 = func(data, a[2])
data_3 = func(data_2, a[3])
result = func(data_3, a[4])

那么,代码可以这样修改:

from functools import reduce
result = reduce(func, [1, 2, 3, 4, 5])

所以,对应到Django中不定项或查询,代码可以修改为:

from django.db.models import Q
from functools import reduce
keywords = ['促销', '打折', '限时']
def func(word_1, word_2):
    return Q(description__contains=word_1) | Q(description__contains=word_2)
item = Product.objects
if len(keywords) >= 2:
    filters = reduce(func, keywords)
else:
    filters = Q(description__contains=keyowrds[0]) if keywords else None
item = item.filter(filters)

这里需要注意,使用reduce的时候,需要保证它的第二个参数能至少被迭代2次。如果可迭代参数为空列表或者不能迭代的对象,那么就会导致报错。如果只能迭代1次,活着列表里面只有一个元素,那么就会直接返回这个元素,不会被传入函数中。只有当列表里面的元素不小于2个,或者可迭代对象能被迭代的次数不小于2次,reduce才能正常工作。

目录
相关文章
|
8月前
|
开发者 Python
Python中的函数式编程:理解map、filter和reduce
【2月更文挑战第13天】 本文深入探讨了Python中函数式编程的三个主要工具:map、filter和reduce。我们将详细解释这些函数的工作原理,并通过实例来展示它们如何使代码更简洁、更易读。我们还将讨论一些常见的误解和陷阱,以及如何避免它们。无论你是Python新手还是有经验的开发者,本文都将帮助你更好地理解和使用这些强大的函数。
|
Python
python中的reduce函数
python中的reduce函数
101 0
python中的reduce函数
|
5月前
|
分布式计算 Python
【python笔记】高阶函数map、filter、reduce
【python笔记】高阶函数map、filter、reduce
|
7月前
|
Python
在Python中,`map()`, `filter()` 和 `reduce()` 是函数式编程中的三个核心高阶函数。
【6月更文挑战第24天】Python的`map()`应用函数到序列元素,返回新序列;`filter()`筛选满足条件的元素,生成新序列;`reduce()`累计操作序列元素,返回单一结果。
48 3
|
8月前
|
Python
python中的reduce(function, iterable[, initializer])
【4月更文挑战第4天】`reduce()` 是 Python 的内置函数(Python 3 需从 `functools` 导入),用于对列表或元组等可迭代对象进行累积操作。它接收一个二元操作函数和一个可迭代对象,连续应用函数至所有元素,最终得到单一结果。可选参数 `initializer` 用于设置初始值。示例展示了使用 `lambda` 计算元素之和、乘积以及带有初始值的例子。
59 0
python中的reduce(function, iterable[, initializer])
|
8月前
|
存储 Python
【Python 基础】解释reduce函数的工作原理
【5月更文挑战第6天】【Python 基础】解释reduce函数的工作原理
|
8月前
|
存储 Python
介绍Python中的函数式编程工具,如`map`、`filter`和`reduce`。
介绍Python中的函数式编程工具,如`map`、`filter`和`reduce`。
56 3
|
8月前
|
Python
Python函数式编程,map(), filter() 和 reduce() 函数的作用是什么?
Python函数式编程,map(), filter() 和 reduce() 函数的作用是什么?
78 4
|
Python
【Python基础】reduce函数详解
【Python基础】reduce函数详解
1056 1
Python 进阶之术 Map Filter Reduce
Python 进阶之术 Map Filter Reduce