BL4CK R4BBIT
BL4CK R4BBITApril 23, 2021, 12:21 p.m.

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

'''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

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

1
Evgenii Legotckoi
  • July 2, 2021, 5:13 a.m.

При работе с двумя формами в одном 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
            }
        )

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

    Comments

    Only authorized users can post comments.
    Please, Log in or Sign up
    AD

    C ++ - Test 004. Pointers, Arrays and Loops

    • Result:50points,
    • Rating points-4
    m

    C ++ - Test 004. Pointers, Arrays and Loops

    • Result:80points,
    • Rating points4
    m

    C ++ - Test 004. Pointers, Arrays and Loops

    • Result:20points,
    • Rating points-10
    Last comments
    ИМ
    Игорь МаксимовNov. 22, 2024, 11:51 a.m.
    Django - Tutorial 017. Customize the login page to Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
    Evgenii Legotckoi
    Evgenii LegotckoiOct. 31, 2024, 2:37 p.m.
    Django - Lesson 064. How to write a Python Markdown extension Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
    A
    ALO1ZEOct. 19, 2024, 8:19 a.m.
    Fb3 file reader on Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
    ИМ
    Игорь МаксимовOct. 5, 2024, 7:51 a.m.
    Django - Lesson 064. How to write a Python Markdown extension Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
    d
    dblas5July 5, 2024, 11:02 a.m.
    QML - Lesson 016. SQLite database and the working with it in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
    Now discuss on the forum
    m
    moogoNov. 22, 2024, 7:17 a.m.
    Mosquito Spray System Effective Mosquito Systems for Backyard | Eco-Friendly Misting Control Device & Repellent Spray - Moogo ; Upgrade your backyard with our mosquito-repellent device! Our misters conce…
    Evgenii Legotckoi
    Evgenii LegotckoiJune 24, 2024, 3:11 p.m.
    добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
    t
    tonypeachey1Nov. 15, 2024, 6:04 a.m.
    google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
    NSProject
    NSProjectJune 4, 2022, 3:49 a.m.
    Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

    Follow us in social networks