diff --git a/recipes/VideoBotsStats.py b/recipes/VideoBotsStats.py index 10e5ad527..4781d4b40 100644 --- a/recipes/VideoBotsStats.py +++ b/recipes/VideoBotsStats.py @@ -33,7 +33,7 @@ TruncYear, Concat, ) -from django.db.models import Count, Avg +from django.db.models import Count, Avg, Q ID_COLUMNS = [ "conversation__fb_page_id", @@ -817,13 +817,10 @@ def get_tabular_data( df["Bot"] = bi.name elif details == "Answered Successfully": successful_messages: MessageQuerySet = Message.objects.filter( + Q(analysis_result__contains={"Answered": True}) + | Q(analysis_result__contains={"assistant": {"answer": "Found"}}), conversation__bot_integration=bi, - analysis_result__contains={"Answered": True}, ) # type: ignore - successful_messages |= Message.objects.filter( - conversation__bot_integration=bi, - analysis_result__contains={"assistant": {"answer": "Found"}}, - ) if start_date and end_date: successful_messages = successful_messages.filter( created_at__date__gte=start_date, created_at__date__lte=end_date @@ -833,13 +830,10 @@ def get_tabular_data( df["Bot"] = bi.name elif details == "Answered Unsuccessfully": unsuccessful_messages: MessageQuerySet = Message.objects.filter( + Q(analysis_result__contains={"Answered": False}) + | Q(analysis_result__contains={"assistant": {"answer": "Missing"}}), conversation__bot_integration=bi, - analysis_result__contains={"Answered": False}, ) # type: ignore - unsuccessful_messages |= Message.objects.filter( - conversation__bot_integration=bi, - analysis_result__contains={"assistant": {"answer": "Missing"}}, - ) if start_date and end_date: unsuccessful_messages = unsuccessful_messages.filter( created_at__date__gte=start_date, created_at__date__lte=end_date