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
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!
- Дмитрий
- May 7, 2024, 9:40 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:60points,
- Rating points-1
d
- dsfs
- April 26, 2024, 4:56 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
Last comments
Qt Linux - Lesson 001. Autorun Qt application under Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Qt WinAPI - Lesson 007. Working with ICMP Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Анатолий КононенкоFeb. 5, 2024, 1:50 a.m.
EVADec. 25, 2023, 10:30 a.m.
Boost - static linking in CMake project under Windows Сделал всё по-как у вас, но выдаёт ошибку [build] LINK : fatal error LNK1104: не удается открыть файл "libboost_locale-vc142-mt-gd-x64-1_74.lib" Хоть убей, не могу понять в чём дел…
Qt/C++ - Lesson 056. Connecting the Boost library in Qt for MinGW and MSVC compilers Для решения твой проблемы добавь в файл .pro строчку "LIBS += -lws2_32" она решит проблему , лично мне помогло.
Now discuss on the forum
добавить qlineseries в функции в функции: "GPlotter::addSeries(QString title, QVector &arr)" я вызываю метод setChart(...), я в конструктор передал адрес на QChartView элемент
BlinCTMay 5, 2024, 5:46 a.m.
Best Indian Food Restaurant In Cincinnati OH Ready to embark on a gastronomic journey like no other? Join us at App india restaurant and discover why we're renowned as the Best Indian Food Restaurant In Cincinnati OH . Whether y…
Evgenii LegotckoiMay 2, 2024, 2:07 p.m.
IscanderCheApril 30, 2024, 4:22 a.m.
При работе с двумя формами в одном View я поступил так
Уже в методе, где проходит валидация обеих форм, можно провести проверки условий между двумя формами.