BL4CK R4BBIT
BL4CK R4BBITСәуір 23, 2021, 12:21 Т.Қ.

Валидация формы

'''models.py'''
class Meter(models.Model):
    TARIFF_CHOICES = (
        ('T1', 'Однотарифный'),
        ('T2', 'Двухтарифный'),
        ('T3', 'Трехтарифный'),
    )
    number_meter = models.CharField(max_length=20, unique=True, verbose_name='Номер счетчика')
    croft_meter = models.ForeignKey(Croft, on_delete=models.PROTECT, verbose_name='Участок')
    type_meter = models.ForeignKey(TypeMeter, on_delete=models.PROTECT, verbose_name='Тип счетчика')
    serial_number = models.CharField(max_length=20, blank=True, verbose_name='Серийный номер счетчика')
    seal_number = models.CharField(max_length=20, blank=True, verbose_name='Номер пломбы')
    date_meter = models.DateTimeField(default=datetime.now(), verbose_name='Дата установки')
    type = models.CharField(max_length=50, choices=TARIFF_CHOICES, verbose_name='Вид тарифа')
    last_reading_single = models.PositiveIntegerField(blank=True, null=True, verbose_name='Показания T1')
    last_reading_two = models.PositiveIntegerField(blank=True, null=True, verbose_name='Показания T2')
    last_reading_three = models.PositiveIntegerField(blank=True, null=True, verbose_name='Показания T3')
    is_active = models.BooleanField(default=True, verbose_name='Установлен')

    def __str__(self):
        return self.number_meter

    class Meta:
        verbose_name = 'Счетчик'
        verbose_name_plural = 'Счетчики'
        ordering = ['croft_meter']


class Indication(models.Model):
    meter = models.ForeignKey(Meter, on_delete=models.PROTECT, verbose_name='Счетчик')
    reading_single = models.PositiveIntegerField(default=0, verbose_name='Показания T1')
    reading_two = models.PositiveIntegerField(default=0, blank=True, verbose_name='Показания T2')
    reading_three = models.PositiveIntegerField(default=0, blank=True, verbose_name='Показания T3')
    date_indication = models.DateTimeField(auto_now_add=True, verbose_name='Дата показаний')
    expenditure = models.PositiveIntegerField(default=0, verbose_name='Расход')

    def __str__(self):
        return self.meter.number_meter

    def save(self, *args, **kwargs):
        if not self.id:
            self.expenditure = self.reading_single - self.meter.last_reading_single
            self.meter.last_reading_single = self.reading_single
            self.meter.save()
        return super(Indication, self).save(*args, **kwargs)

    class Meta:
        verbose_name = 'Показания'
        verbose_name_plural = 'Показания'



'''views.py'''
class AddMeterView(SuccessMessageMixin, LoginRequiredMixin, CreateView):
    model = Meter
    template_name = 'crofts/add_meter.html'
    form_class = AddMeterForm
    success_url = reverse_lazy('main:meters_user')

    def get(self, request=None, **kwargs):
        form = self.form_class()
        form.fields['croft_meter'].queryset = Croft.objects.filter(Q(owner=request.user) | Q(grower=request.user))
        return render(request, self.template_name, {'form': form})


class AddIndicationView(SuccessMessageMixin, LoginRequiredMixin, CreateView):
    model = Indication
    template_name = 'main/profile/profile_meters/add_indication.html'
    form_class = AddIndicationForm
    success_url = reverse_lazy('main:meters_user')

    def get(self, request=None, *args, **kwargs):
        form = self.form_class()
        form.fields['meter'].queryset = Meter.objects.filter(Q(croft_meter__owner=request.user) | Q(croft_meter__grower=request.user))
        return render(request, self.template_name, {'form': form})

'''forms.py'''
class AddMeterForm(forms.ModelForm):
    last_reading_single = forms.IntegerField(label='Показания')

    class Meta:
        model = Meter
        fields = ('number_meter', 'croft_meter', 'type_meter', 'serial_number', 'seal_number',
                  'date_meter', 'type', 'last_reading_single')


class AddIndicationForm(forms.ModelForm):
    reading_single = forms.IntegerField(label='Показания')

    class Meta:
        model = Indication
        fields = ('meter', 'reading_single')

Не могу проверить условие для формы
если reading_single < meter.last_reading_single

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

1
Evgenii Legotckoi
  • Шілде 2, 2021, 5:13 Т.Ж.

При работе с двумя формами в одном View я поступил так

class EditMain(View):
    template_name = 'users/edit/main.html'
    title = _('Edit')

    def get(self, request):
        return render(
            request=request,
            template_name=self.template_name,
            context={
                'title': self.title,
                'user_form': forms.UserForm(instance=request.user),
                'profile_form': forms.ProfileForm(user=request.user, instance=request.user.profile)
            }
        )

    def post(self, request):
        user_form = forms.UserForm(data=request.POST, instance=request.user)
        profile_form = forms.ProfileForm(user=request.user, data=request.POST, files=request.FILES,
                                         instance=request.user.profile)

        if user_form.is_valid() and profile_form.is_valid():
            user_form.save()
            profile_form.save()
            return redirect(reverse('users:edit_main'))

        return render(
            request=request,
            template_name=self.template_name,
            context={
                'title': self.title,
                'user_form': user_form,
                'profile_form': profile_form
            }
        )

Уже в методе, где проходит валидация обеих форм, можно провести проверки условий между двумя формами.

    Пікірлер

    Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
    Кіріңіз немесе Тіркеліңіз
    OI
    • Ora Iro
    • Жел. 24, 2024, 6:38 Т.Ж.

    C++ - Тест 001. Первая программа и типы данных

    • Нәтиже:40ұпай,
    • Бағалау ұпайлары-8
    AD

    C++ - Тест 004. Указатели, Массивы и Циклы

    • Нәтиже:50ұпай,
    • Бағалау ұпайлары-4
    m
    • molni99
    • Қаз. 26, 2024, 1:37 Т.Ж.

    C++ - Тест 004. Указатели, Массивы и Циклы

    • Нәтиже:80ұпай,
    • Бағалау ұпайлары4
    Соңғы пікірлер
    ИМ
    Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
    Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    Evgenii Legotckoi
    Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
    A
    ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
    Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
    ИМ
    Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
    Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
    d
    dblas5Шілде 5, 2024, 11:02 Т.Ж.
    QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
    Енді форумда талқылаңыз
    Evgenii Legotckoi
    Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
    t
    tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
    NSProject
    NSProjectМаусым 4, 2022, 3:49 Т.Ж.
    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
    9
    9AnonimҚаз. 25, 2024, 9:10 Т.Ж.
    Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

    Бізді әлеуметтік желілерде бақылаңыз