Итак, я довольно новичок в Django и пытаюсь реализовать на практике следующую идею: в моей форме создания объекта я хочу, чтобы пользователи заполнили поле даты, чтобы поставить временную метку на объект.Подвох в том, что я хочу сделать только два дня на выбор - сегодня и завтра.Я не хочу использовать поле DateTime и заставлять пользователей вводить даты вручную, поскольку это выглядит довольно некрасиво и не очень удобно в использовании.Я решил попробовать и реализовать поле выбора.Он отображается хорошо, но до сих пор я не понял, как сделать так, чтобы данные формы передавались как допустимые.Я копался с pdb, в результате прочитал о методах очистки / проверки, но я до сих пор не знаю, как заставить это работать.То, что я уже пробовал: добавление функций, которые возвращают сегодня и завтра как объекты даты и как строки (вот последний), текст ошибки: выберите правильный выбор, это не один из доступных вариантов, я считаю, что он не работает во время clean ()метод как-то.Или, если это не разумная идея (а это, вероятно, нет), что может быть альтернативой?
models.py:
def get_today():
return datetime.date.strftime( datetime.datetime.now().date(), format="%Y-%m-%d")
def get_tomorrow():
return datetime.date.strftime(((datetime.datetime.now() + datetime.timedelta(days=1)).date()), format="%Y-%m-%d")
class User(AbstractUser):
slug = models.SlugField(max_length=100, unique=True)
def save(self, *args, **kwargs):
self.slug = slugify(self.username)
super(User, self).save(*args, **kwargs)
class Task(models.Model):
TODAY = get_today
TOMORROW = get_tomorrow
DATE_SELECTION = (
(TODAY, "Today"),
(TOMORROW, "Tomorrow"),
)
task_title = models.CharField(verbose_name="Название задачи: ", max_length=150)
task_description = models.TextField(verbose_name="Описание: ", max_length=1000)
task_user = models.ForeignKey('User', on_delete=models.CASCADE)
task_date = models.DateField(choices=DATE_SELECTION)
def __str__(self):
return self.task_title
представление на основе классов из представлений.Py, которую я использую для обработки формы:
class CreateTask(CreateView):
model = Task
form_class = TaskForm
success_url = '/{user}'
def get(self, request, *args, **kwargs):
form = TaskForm()
return render(request, 'create_task.html', {'form': form})
def post(self, request, *args, **kwargs):
form = TaskForm(request.POST)
if form.is_valid():
task = form.save(commit=False)
task = Task(**form.cleaned_data)
task.task_user = request.user
task.save()
messages.add_message(request, messages.INFO, "Task %s was successfully created!" % task.task_title)
return redirect('tasks:user_home', user=request.user)
else:
return render(request, 'create_task.html', {'form': form, 'errors':form.errors})
forms.py
class TaskForm(forms.ModelForm):
task_date=forms.DateField(input_formats="%Y-%m-%d")
class Meta:
model = Task
fields = ['task_title', 'task_description']
ОБНОВЛЕНИЕ: после многих экспериментов и исследований я создал следующее решение:
models.py
class Task(models.Model):
task_title = models.CharField(verbose_name="Название задачи: ", max_length=150)
task_description = models.TextField(verbose_name="Описание: ", max_length=1000)
task_user = models.ForeignKey('User', on_delete=models.CASCADE)
task_date = models.DateField()
def __str__(self):
return self.task_title
(^^^ обратите внимание на отсутствие поля выбора) и forms.py:
def get_today():
return datetime.datetime.now().date()
def get_tomorrow():
return (datetime.datetime.now() + datetime.timedelta(days=1)).date()
TODAY = get_today
TOMORROW = get_tomorrow
DATE_SELECTION = (
(TODAY, "Today"),
(TOMORROW, "Tomorrow"),
)
class TaskForm(forms.ModelForm):
task_date = forms.DateField(input_formats=["%Y-%m-%d"], widget=forms.Select(choices=DATE_SELECTION))
class Meta:
model = Task
fields = ['task_title', 'task_description']
(^^^ отметьте выборвиджет, input_formats, который всегда должен быть списком)