It may save you some time if you're in the case of this link : https://stackoverflow.com/questions/11801363/django-q-with-joins-functioning-incorrectly-bug
It worked for me at least.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | def put_Q_negations_to_leaves(
query_filter: Q,
negate: bool = False,
debug: bool = False,
):
negate_below = (negate != query_filter.negated) # XOR
if debug:
logger.info(
f"put_Q_negations_to_leaves() query_filter:{query_filter}"
f" negate:{negate} negate_below:{negate_below}"
)
true_kwargs = {
"_connector": query_filter.connector,
"_negated": False,
}
new_children = []
for child in query_filter.children:
if debug:
logger.info(child.__repr__())
if not isinstance(child, Q):
if negate_below:
new_child = ~Q(child)
else:
new_child = child
else:
new_child = put_Q_negations_to_leaves(child, negate=negate_below)
if debug:
logger.info(new_child.__repr__())
new_children.append(new_child)
if len(new_children) == 1:
# One child
if isinstance(new_children[0], Q):
return new_children[0]
else:
true_kwargs["_negated"] = negate_below
if negate_below:
if true_kwargs["_connector"] == Q.AND:
true_kwargs["_connector"] = Q.OR
else:
true_kwargs["_connector"] = Q.AND
return Q(*new_children, **true_kwargs)
|
More like this
- Template tag - list punctuation for a list of items by shapiromatron 1 year ago
- JSONRequestMiddleware adds a .json() method to your HttpRequests by cdcarter 1 year ago
- Serializer factory with Django Rest Framework by julio 1 year, 7 months ago
- Image compression before saving the new model / work with JPG, PNG by Schleidens 1 year, 8 months ago
- Help text hyperlinks by sa2812 1 year, 8 months ago
Comments
It took me a few hours to code it and I may have forgot some special cases. Be sure to test in your specific use case.
#
Please login first before commenting.