微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

超过某个时间点时的通知Python

如何解决超过某个时间点时的通知Python

我想创建一个待办事项列表,我可以在其中安排每项任务的日期和时间。我的目标是在提供的 datetime 等于当前时间时获得某种响应。例如,我安排在周六晚上的周一下午 6 点洗衣服。两天后(周一下午 6 点),我想收到通知,告知我应该洗衣服

请注意,关键思想可以在 views.py 中的 index() 函数 中找到,包括 if 语句的第一行。

这是我的代码urls.py

from django.urls import path

from . import views

urlpatterns = [
    path("",views.index,name="index"),path("<int:aufgabenzettel_id>",views.details,name="details"),path("add/",views.add,name="add"),path("delete/<int:aufgabenzettel_id>",views.delete,name="delete"),path("edit/<int:aufgabenzettel_id>",views.edit,name="edit"),path("update/<int:aufgabenzettel_id>",views.update,name="update")
]

models.py

from django.db import models

# Create your models here.
class Aufgabenzettel(models.Model):
    Aufgabeselbst = models.CharField(max_length=64)
    Datum = models.DateTimeField(auto_Now_add=True)
    Geplant = models.DateTimeField(auto_Now_add=False,auto_Now=False)

    def __str__(self):
        return f"{self.Aufgabeselbst}"

views.py(重要的部分可以在第一行的索引函数中找到,包括if语句)

from django.db.models.fields import DateTimeField
from django.http.response import HttpResponseRedirect
from django.shortcuts import render
from django.urls import reverse
from django.utils import timezone
from datetime import datetime

from .models import Aufgabenzettel

# Create your views here.

def index(request):
    Now = datetime.Now()
    Aufgaben_items = Aufgabenzettel.objects.all().order_by("-Geplant") #arrange objects in the correct order
    for Aufgabenzettel.Geplant in Aufgaben_items: #run through the loop and...
        if Aufgabenzettel.Geplant == Now: #...search for items in the database where the scheduled time ("Geplant") is equal to the current time
            return render (request,"aufgabenzettel/add.html") #response in any way e.g. by returning the add.html 
    return render(request,"aufgabenzettel/index.html",{
        "Aufgabenliste":Aufgabenzettel.objects.all(),#currently not used
        "Aufgaben_items":Aufgaben_items
    })

def details(request,aufgabenzettel_id):
    aufgabenzettel = Aufgabenzettel.objects.get(pk=aufgabenzettel_id)
    creationDate = aufgabenzettel.Datum
    dueDate = aufgabenzettel.Geplant
    return render(request,"aufgabenzettel/details.html",{
        "details":aufgabenzettel,"creationDate": creationDate,"dueDate":dueDate
    })

def add(request):
    addDatum = timezone.Now()
    if request.method == "POST":
        Aufgabe = request.POST["Hinzufügen"]
        geplantes_datum = request.POST["DatumFeld"]
        Aufgabenzettel.objects.create(Aufgabeselbst=Aufgabe,Datum=addDatum,Geplant=geplantes_datum) #Aufgabenname und Aufgabendatum erstellen
        return HttpResponseRedirect(reverse("index"))
    return render(request,"aufgabenzettel/add.html")

def delete(request,aufgabenzettel_id):
    aufgabenzettel = Aufgabenzettel.objects.get(pk=aufgabenzettel_id)
    aufgabenzettel.delete()
    return HttpResponseRedirect(reverse("index"))

def edit(request,aufgabenzettel_id):
    aufgabenzettel = Aufgabenzettel.objects.get(pk=aufgabenzettel_id)
    return render(request,"aufgabenzettel/edit.html",{
        "details":aufgabenzettel
    })

def update(request,aufgabenzettel_id):
    if request.method == "POST":
        Aufgabe = Aufgabenzettel.objects.get(pk=aufgabenzettel_id)
        Aufgabe.Aufgabeselbst = request.POST["Bearbeiten"]
        Aufgabe.save()
        return HttpResponseRedirect(reverse("index"))
    return render(request,"aufgabenzettel/edit.html")

index.html

{% extends "aufgabenzettel/layout.html" %}

{% block body %}
<h1 id="MeineAufgaben">Meine Aufgaben</h1>
    <table>
        {% for Aufgabeselbst in Aufgaben_items %}
            <tr>
                <td>
                    <a href="{% url 'details' Aufgabeselbst.id %}"> 
                        {{ Aufgabeselbst }}
                    </a>
                </td>
                <td>
                    <form action="{% url 'delete' Aufgabeselbst.id %}" method="post">
                        {% csrf_token %}
                    <button type="submit"  id="löschenbtn">Löschen</button>
                </form>
                </td>
                <td>
                    <form action="{% url 'edit' Aufgabeselbst.id %}" method="post">
                        {% csrf_token %}
                    <button type="submit" value="{{ details }}" class="bearbeitenbtn">Bearbeiten</button>
                    </form>
                </td>
            </tr>
        {% endfor %}
    </table>
    <h2>
        <a href="{% url 'add' %}" id="neuebtn">Neue Aufgabe erstellen</a>
    </h2>
{% endblock %}

add.html

{% extends "aufgabenzettel/layout.html" %}

{% block body %}
    <h1>Füge eine neue Aufgabe hinzu!</h1>
    <form action="{% url 'add' %}" method="post">
        {% csrf_token %}
        <input type="text" name="Hinzufügen" placeholder="Neue Aufgabe">
        <input type="datetime-local" name="DatumFeld">
        <button type="submit" id="Hinzufügen">Hinzufügen</button>
    </form>
{% endblock %}

details.html

{% extends "aufgabenzettel/layout.html" %}

{% block body %}
    <h1>{{ details }}</h1>
    <h3>Erstellt: {{ creationDate }}</h3>
    <h2>Geplant: {{ dueDate }}</h2>
    <a href="{% url 'index' %}">Zurück zu Aufgabe</a>
{% endblock %}

edit.html

{% extends "aufgabenzettel/layout.html" %}

{% block body %}
    <h2>Bearbeite deine Aufgabe "{{ details }}"</h2>
    <form action="{% url 'update' details.id %}" method="post">
    {% csrf_token %}
        <input type="text" name="Bearbeiten" value="{{details}}">
        <button type="submit" class="bearbeitenbtn">Bearbeiten</button>
    </form>
    <a href="{% url 'index' %}">Zurück zu Aufgabe</a>
{% endblock %}

layout.html

{% load static %}
<!DOCTYPE html>
<html lang="de">
    <head>
        <Meta name="viewport" content="width=device-width,initial-scale=1.0">
        <title>Aufgabenzettel</title>
        <link rel="stylesheet" href="{% static '/css/main.css' %}">
    </head>
    <body>
        {% block body %}
        {% endblock %}
    </body>

</html>

我没有收到错误或任何信息,但代码未按预期运行。我只希望索引函数遍历 models.py数据库 Aufgabenzettel 中的每个元素,并且如果它检测到某个元素,其中计划时间与当前时间相对应行动(在这种情况下,重定向到 add.html 是ecpected)应该发生。但是我没有得到任何这样的回应...

像往常一样,我感谢各种解决方案或帮助!

解决方法

您以错误的方式比较日期时间,这就是为什么您的 if 条件失败 (Aufgabenzettel.Geplant == now) 。 尝试像这样比较它们:

In [1]: from datetime import datetime
In [2]: past = datetime.now()
In [3]: present = datetime.now()
In [4]: present.strftime('%Y-%m-%d %H:%M:%S') == past.strftime('%Y-%m-%d 
%H:%M:%S')
Out[17]: False
In [5]: present.strftime('%Y-%m-%d %H:%M') == past.strftime('%Y-%m-%d %H:%M')
Out[2]: True

通常将日期时间转换为iso格式后进行比较。您还可以使用时区中的函数 .isoformat()。

从这里拿起它:How to compare two Datetime field in Django

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?