Проблема с полем Django Datetime Choice - PullRequest
0 голосов
/ 11 июня 2018

Итак, я довольно новичок в 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, который всегда должен быть списком)

1 Ответ

0 голосов
/ 12 июня 2018

ОБНОВЛЕНИЕ: после множества экспериментов и исследований я создал следующее решение:

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, который всегда должен быть списком)

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...