Is there a way to take a list of django query expresses (e.g. Q(first_name="Jordan")
, where Q
is django.db.models.Q
) and bitwise OR them together?
In other words, I have something like this:
search_string = "various search terms"
And I want to do this:
search_params = [Q(description__icontains=term) for term in re.split(r'\W', search_string)]
search_params = something_magical(search_params)
results = Record.objects.filter(search_params)
where search_params
now is equivalent to Q(description__icontains="various") | Q(description__icontains="search" | Q(description__icontains="terms"
I know it would be possible with a function like this:
def something_magical(lst):
result = lst[0]
for l in lst[1:]
result |= l
return result
So I'm wondering if this functionality is already built into Python (and I'm assuming it's more optimized than my function here).
Although I'm interested in it for this application, I'm also just interested in it theoretically.