BL4CK R4BBIT23 апреля 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
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
l
- laei
- 23 апреля 2024 г. 6:19
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:10баллов,
- Очки рейтинга-10
Последние комментарии
Qt Linux - Урок 001. Автозапуск Qt приложения под Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Урок 007. Работаем с ICMP Ping в Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий Кононенко4 февраля 2024 г. 22:50
EVA25 декабря 2023 г. 7:30
Boost - статическая линковка в CMake проекте под Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Урок 056. Подключение библиотеки Boost в Qt для компиляторов MinGW и MSVC Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Сейчас обсуждают на форуме
DA
Unlock Your Aesthetic Potential: Explore MSC in Facial Aesthetics and Cosmetology in India Embark on a transformative journey with an msc in facial aesthetics and cosmetology in india . Delve into the intricate world of beauty and rejuvenation, guided by expert faculty and …
Dr Gangil Academics20 апреля 2024 г. 4:45
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Евгений, добрый день! Такой вопрос. Верно ли следующее утверждение: Любое Android-приложение, написанное на Java/Kotlin чисто теоретически (пусть и с большими трудностями) можно написать и на C+…
Павел Дорофеев13 апреля 2024 г. 23:35
Вернуть старое поведение QComboBox, не менять индекс при resetModel Добрый день! У нас много проектов в которых используется QComboBox, в версии 5.5.1, когда модель испускает сигнал resetModel, currentIndex не менялся. В версии 5.15 при resetModel происходит try…
При работе с двумя формами в одном View я поступил так
Уже в методе, где проходит валидация обеих форм, можно провести проверки условий между двумя формами.