django - 如何使用 django 使用 datefield 检索数据?

标签 django python-3.x postgresql

我需要使用 Django 日期字段从数据库中检索数据。尝试使用 Datefield 检索数据。我正在使用 Django 2.0、Bootstrap 4、PostgreSQL。

#forms.py
from django import forms

class StatusReportForm(forms.Form):
    created_date=forms.DateField(widget=forms.TextInput(attrs=
                            {
                                'class':'datepicker'
                            })) 

#views.py
from django.shortcuts import render, get_object_or_404

# Create your views here.
from django.views.generic import DetailView

from .models import Statusreport
from .forms import StatusReportForm

def statusreport(request):
   form = StatusReportForm()
     context = {
         form: form
         }
  return render(request, "statusreport.html", context)

class StatusReportDetailView(DetailView):
    model = Statusreport
    template_name = 'statusreport-detail.html'
    def get_object(self):
        instance = get_object_or_404(Statusreport, slug=self.kwargs['slug'])
     return instance
 #models.py
 class Statusreport(models.Model):

      created_date= models.DateField()
      taskname = models.CharField(max_length=200)
      slug = models.SlugField(null=True, blank=True)
      def __str__(self):
          return self.taskname

      def get_absolute_url(self):
          return reverse('statusreport:statusreport-detail', kwargs={'slug': 
          self.slug})

 def pre_save_statusreport_receiver(instance, *args, **kwargs):
     if not instance.slug:
       instance.slug = instance.created_date
 pre_save.connect(pre_save_statusreport_receiver, sender= Statusreport)

 #statusreport.html

 <main class="container">
   <form>
       <div class="row" style="padding-top: 100px">
           <div class="col">
              <label class = 'control-label' for="date">Select Date: </label>
              <input data-date-format="dd/mm/yyyy" id="datepicker">
            </br>
        </br>
            <a href="#" class="btn btn-info btn-md active" role="button" 
             aria-pressed="true">Get Reports</a>
          </div>
       </div>
     </form>
  </main>
   <script type="text/javascript">
   $('#datepicker').datepicker({
      weekStart: 1,
      daysOfWeekHighlighted: "6,0",
      autoclose: true,
      todayHighlight: true,
  });
  $('#datepicker').datepicker("setDate", new Date());
  </script>

注意:我需要它像点击“获取报告”按钮那样工作,它需要移动到 http://localhost:8000/statusreport/。 {{创建日期}}/

但我无法获取报告。

最佳答案

   <form method=POST action={% url 'get_posts_from'%}>
       {% csrf_token %}
       <div class="row" style="padding-top: 100px">
           <div class="col">
              <label class = 'control-label' for="date">Select Date: </label>
              <input name='date-needed' data-date-format="dd/mm/yyyy" id="datepicker">
            </br>
        </br>
            <a href="#" class="btn btn-info btn-md active" role="button" 
             aria-pressed="true">Get Reports</a>
          </div>
       </div>
     </form>

首先你必须让你的表单方法发布

然后您将 action 添加到将管理已发布数据的 View 中作为您的 url

然后将csrf_token添加到表单

然后你必须给 #datepicker name 所以当你去你的 View 时

你得到 request.POST["date"] 这是你在表单中选择的日期

urls.py

url(r'^(?P<date>\d{4}-\d{2}-\d{2})/$', views.get_posts_from, name='get_posts_from')

然后在 View 中

def get_posts_from(request, date):
    if request.method =="POST":
         date = request.POST['date']
    #here you put your logic the date can be either picked from
    #the post or even trough the URL on his own 
    return HttpResponse("POSTS from",date)

关于django - 如何使用 django 使用 datefield 检索数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51615054/

相关文章:

postgresql - 复制命令 : copy only specific columns from csv

Django:如何通过模板获取由外键连接的数据?

django - 管理员中的 list_filter

django - 工具错误 : Command 01_migrate failed on Amazon LM2

python-3.x - 在python中将数据帧行转换为没有列索引的值字符串

c# - Fluent NHibernate 自动删除数据

django - Amazon RDS 快速丢失内存。那是正常的吗?

python - 如何使用 dbf 模块更新记录

python - 为什么函数标签在该函数的范围内,但类方法标签不在其自身范围内?

django - Docker - psql : django. db.utils.OperationalError: FATAL: 角色 "admin"不存在