【Django-meeting系统】booking_end_date_copy = booking_end_date + dt.timedelta(days=1)

debug:发现9号和10号数据是重叠的

在这里插入图片描述

解法:日期有错误

将booking_end_date = booking_end_date + dt.timedelta(days=1)改成booking_end_date_copy = booking_end_date + dt.timedelta(days=1)

# 定义全局函数def
booking_all = booking.objects.all()

def count_approve_hour_and_percentage(classroom_name,booking_start_date,booking_end_date):
    # booking_end_date结束日期加上一天
    booking_end_date_copy = booking_end_date + dt.timedelta(days=1)
    diff= (booking_end_date_copy - booking_start_date)
    diff_days = diff.days
    #diff_days = 30
    #print('diff.days',diff.days)
    
    fenzi = booking_all.filter(Q(booking_classroom_name__contains=classroom_name) & Q(booking_date__gte=booking_start_date) & Q(booking_date__lte=booking_end_date) & Q(booking_approve_Y_N='Y'))
    # fenzi = booking_all.filter(Q(booking_classroom_name__contains=classroom_name) & Q(booking_date__gte=booking_start_date) & Q(booking_date__lte=booking_end_date) & Q(booking_approve_Y_N='Y'))
    fenzi_sum = 0
    for each in fenzi:
        print('each',each.booking_date,each.booking_id)
        today_d = dt.date.today()
        total_time = dt.datetime.combine(today_d,each.booking_end_time) - dt.datetime.combine(today_d,each.booking_start_time)
        total_minutes = int(str(total_time).split(':')[0])*60 + int(str(total_time).split(':')[1])+1
        fenzi_sum += total_minutes
    # fenzi_percentage = round(100* fenzi_sum / (30*60*8),1)
    fenzi_percentage = round(100* fenzi_sum / (diff_days*60*8),1)
    # print(fenzi_percentage,fenzi_sum)
    return fenzi_percentage,fenzi_sum

改善后的图
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值