如何使用开始时间和结束时间在行之间创建缓冲区



我正在尝试打印出可用空格作为表中每行之间的缓冲区。有没有办法让我在 django 模板中做到这一点?这是我拥有的当前代码。

            <table id="upcomingtable" border="1" style="border-collapse:collapse;">
                <tr>
                    <th>Course</th>
                    <th>Title</th>
                    <th>Professor</th>
                    <th>Start</th>
                    <th>End</th>
                </tr>
            {% for next in upcoming %}
                <tr> 
                    <td>{{ next.course }}</td>
                    <td>{{ next.title }}</td>
                    <td>{{ next.prof }}</td>
                    <td>{{ next.stime }}</td>
                    <td>{{ next.etime }}</td>
                </tr>
                <tr><td></tr> <!--Buffer here-->
            {% endfor %}
            </table>

这是我当前即将推出的查询:

upcoming = Class.objects.filter(building__exact=b, floor__exact=f, room__exact=r, days__icontains=dayletter(day), etime__gt=datetime.datetime.now().time()).distinct().order_by('stime')

基本上,我想获取结束时间(etime)并找到它与下一个开始时间之间的区别,该开始时间与下一个开始时间迭代,并在这些行之间创建一个缓冲区。例如,现在的结束时间是下午 3:00,下一个开始时间是下午 3:15,我想在打印出实际行之前创建一个行缓冲区。

Ex.
    3:00    info info info
    blank
    blank
    blank
    3:15    info info info

用于在 views.py 内循环

 for i, item in enumerate(range(len(upcoming)-1)):
    s1 = upcoming[i].etime
    s2 = upcoming[i+1].stime
    d2 = s2.hour*60 + s2.minute
    d1 = s1.hour*60 + s1.minute 
    d = d2 - d1
    if (d>0):
        upcoming[i].span = d/5

谢谢大家,我感谢你们的帮助!

如果我

理解正确,空白行的数量取决于记录之间的时差,对吧?如果是这样,您可以尝试这样的事情:

upcoming = list(upcoming)
for i, item in enumerate(upcoming[:-1]):
    item.span = range(1, upcoming[i+1].sdate - item.edate)   #actually, get the time difference in minutes and divide by some coefficient - how many minutes should pass for the new blank row to be inserted

然后在模板中:

{% for row in next.span %}
    <tr><td colspan="5">&nbsp;</td></tr>
{% endfor %}

最新更新