在两个日期之间搜索,如果存在 - django - ajax

Posted

技术标签:

【中文标题】在两个日期之间搜索,如果存在 - django - ajax【英文标题】:search between two dates, if exists - django - ajax 【发布时间】:2022-01-17 07:26:40 【问题描述】:

我正在尝试通过 ajax 响应将两个日期从模板发送到后端,以检查这两个日期是否存在!如果不存在则返回整个数据,但如果存在只返回这两个范围之间的数据

def dateTimePrice(request):
   start = request.GET.get('from')
   end = request.GET.get('to')
   print(start,end)#
   if start and end:
        datetimes = ImeiInvoice.objects.filter(invoice__created_at__range=(start,end)).annotate(
            total_price=Sum(
                (F('price')) - F('discount'),output_field=DecimalField(max_digits=20,decimal_places=3))
        ).annotate(
            total_quantity=(
                Count('pk')
            )
        ).aggregate(
            all_price=Sum(F('total_price')),
            all_qnt=Sum(F('total_quantity'))
        )
    
   else:
        datetimes = ImeiInvoice.objects.all().annotate(
            total_price=Sum(
                (F('price')) - F('discount'),output_field=DecimalField(max_digits=20,decimal_places=3))
        ).annotate(
            total_quantity=(
                Count('pk')
            )
        ).aggregate(
            all_price=Sum(F('total_price')),
            all_qnt=Sum(F('total_quantity'))
        )
return JsonResponse(datetimes,safe=False)

@login_required
def dateTimePriceTemp(request):
    return render(request,'myapp/datetimes.html')

这是我的 GET 表单,用于获取两个日期

$(document).ready(function()
    const spinner = document.getElementById('spinnerDateTimePrice')
    const start_date = new Date($('#from').val());
    const end_date = new Date($('#to').val());
    console.log(start_date)
    console.log(end_date)
    if(start_date && end_date)
        data=
        'from':start_date,
        'to':end_date            
        
    
        function dateTimePrices()        
            $.ajax(
                type:'GET',
                url:'/prices/dateTime/data',
                data:data,                
                success:function(data)
                    const datetimes = data;
                    var k = '<tbody>';
                    if(datetimes)
                        k+= '<tr>';
                            k+= '<td>' + datetimes["all_qnt"] + '</td>';
                            k+= '<td>' + datetimes['all_price'] + '</td>';

                        k+= '</tr>'                    
                    else
                        k+= '<td class="p-2 text-xs border border-purple-900 md:text-base textpurple" colspan=6>found nothing</td>'
                    
                    k+='</tbody>'
                    document.getElementById('datetime_list').innerHTML = k        
                                
            )        
            
        dateTimePrices();    
)
    <form action="" method="GET">

        <div class="col-11 p-1 mt-1 mx-auto text-center row rtl ">
            <p class="col-12 col-sm-6 mx-auto text-left row">
            <img src="icons/date.svg" class="ml-1" >  
            from  
            <input type="date" class="form-control col-9 mr-1" name="from" id="from"> 
            </p> 
            
            <p class="col-12 col-sm-6 mx-auto text-right row">
                <img src="icons/date.svg" class="ml-1" >  
                to
                <input type="date" name="to" class="form-control col-9 mr-1" id="to">   
            </p>
            <button class="btn btn-info col-8 col-sm-5 col-md-3 mx-auto">search</button>
        </div> 
    </form>

我必须检查输入日期是否存在然后将 data 变量调用到 ajax 中,但现在即使我没有任何搜索仍然假装日期存在并从服务器端返回此错误

django.core.exceptions.ValidationError: ['“Invalid Date” value 的格式无效。它必须是 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] 格式。'] 非常感谢您的帮助..

【问题讨论】:

【参考方案1】:

我认为您需要转换 GET 参数中的值

start = request.GET.get('from')
end = request.GET.get('to')

先将 str/None 放入日期时间对象中。

【讨论】:

在控制台中它只是返回无效值,即使我们可以从控制台获取日期

以上是关于在两个日期之间搜索,如果存在 - django - ajax的主要内容,如果未能解决你的问题,请参考以下文章

两个日期之间的 Wordpress 搜索

什么是 django 查询来查找搜索日期在两列之间的记录不是?

在 django 查询集中的两个日期之间有可能获得几个月?

Django ORM 验证数据库中的一行

在两个不同的日期之间搜索[重复]

如何在两个日期之间搜索以下数据?