Duha22RUS31 мая 2022 г. 10:23
Подсчет суммы баллов в Django
Создаются вопросы с выбором ответа, в модели решил создать к каждому выбору ответа определенный балл.. Теперь как мне сделать общий подсчет баллов в конце опроса, например по нажатию на кнопку, просто сумма баллов?
На форму выводятся все вопросы из бд
Что-то типо такого
Ну или может я совсем не по тому пути пошёл
#models.py class Question(models.Model): name = models.CharField('Вопрос', max_length=100) def __str__(self): return self.name class Meta: verbose_name = 'Вопрос' verbose_name_plural = 'Вопросы' class Option(models.Model): name = models.CharField('Вариант ответа', max_length=100) score = models.IntegerField('Количество баллов', default=0) option = models.ForeignKey(Question, on_delete=models.CASCADE) def __str__(self): return self.name class Meta: verbose_name = 'Поле для выбора' verbose_name_plural = 'Поля для выборов' class Complaint(models.Model): name = models.ForeignKey(to=Patient, on_delete=models.CASCADE, default=1) question = models.ForeignKey(to=Question, on_delete=models.CASCADE, default=1) option = models.ForeignKey(to=Option, on_delete=models.CASCADE, default=1) def __str__(self): return self.name class Meta: verbose_name = 'Анкетирование' verbose_name_plural = 'Анкетирования'
#forms.py class OptionForm(ModelForm): series = ModelChoiceField(label='Ответ', queryset=Option.objects.all()) pat = ModelChoiceField(label='Пациент', queryset=Patient.objects.order_by('name')) score = Option.objects.order_by('score') def __init__(self, *args, **kwargs): super().__init__(*args, **kwargs) self.fields['option'].queryset = Option.objects.none() class Meta: model = Complaint fields = ('__all__')
#views.py def add_complaint(request): error = '' if request.method == 'POST': form = OptionForm(request.POST) if form.is_valid(): form.save() return redirect('database_home') else: error = 'Ошибка добавления' compla = Question.objects.order_by('name') # score = Option.objects.order_by('score') # ball = Option.objects.filter(option_id=score) form = OptionForm() data = {'form': form, 'error': error, 'compla': compla} return render(request, 'database/add_complaint.html', data)
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.Вам это нравится? Поделитесь в социальных сетях!
Комментарии
Только авторизованные пользователи могут публиковать комментарии.
Пожалуйста, авторизуйтесь или зарегистрируйтесь
Пожалуйста, авторизуйтесь или зарегистрируйтесь
AD
- Akiv Doros
- 11 ноября 2024 г. 14:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50баллов,
- Очки рейтинга-4
m
- molni99
- 26 октября 2024 г. 1:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80баллов,
- Очки рейтинга4
m
- molni99
- 26 октября 2024 г. 1:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20баллов,
- Очки рейтинга-10
Последние комментарии
Как написать игру на Qt - Урок 3. Взаимодействие с другими объектами what is priligy tablets What happens during the LASIK surgery process
Использование переменных объявленных в CMakeLists.txt внутри C++ файлов where can i buy priligy online safely Tom Platz How about things like we read about in the magazines like roid rage and does that really
Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
Сейчас обсуждают на форуме
добавить qlineseries в функции PMID 35774217 Free PMC article priligy cvs
Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
IscanderChe31 октября 2024 г. 15:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
ИМ
Реализация навигации по разделам Спасибо Евгений!
Игорь Максимов3 октября 2024 г. 4:05
1) я бы рекомендовал убрать default для ForeignKey - это не безопасно
2) форма не совсем понятна (но я хз - не знаю задачи)
3) View, как мне кажется стоит переписать на что-то похожее на
ошибки, если они выявятся на этапе form.is_valid можно обработать в шаблоне через https://docs.djangoproject.com/en/4.0/ref/forms/api/#django.forms.Form.add_error . они будут информативнее
по поводу основного вопроса:
https://docs.djangoproject.com/en/4.0/topics/db/aggregation/
https://docs.djangoproject.com/en/4.0/ref/models/querysets/#sum
Я не пойму, почему-то я пытаюсь вернуть значения score модели Option.. но он мне возвращает просто имена всех объектов.. тоесть в вопросе на первом скрине видно, что я вводил баллы 4, 0, 0.. а он мне возвращает имена объектов, я не пойму, ка кне просто из бд вывести эти числа, уже столько всего перечитал, пробовал разные способы, никак не пойму(
1) покажите шаблон
2) я не могу понять, что должно отображаться в 3 колонке - баллы за ответ, написанный в 1 колонке или что-то еще?
я бы предложил сделать подругому - разделить логику формирования информации и форму. форму лучше сделать через FormSet
тогда логика будет примерно такая
страница со списком пациентов и ссылкой на форму добавления пацента -> страница пациента с вопросами, ответами, баллами за ответ и суммой баллов + ссылка на форму для заполнения/изменения ответов
если есть код на github, киньте ссылку, я могу сделать PR с тем, что я имею в виду
https://github.com/Duha22RUS/drf4
Вообще в идеале чтобы показывал баллы в зависимости от выбранного ответа)
Третью колонку я вывожу для того, чтобы видеть, что мне возвращается именно баллы. Т.к. сейчас нет смысла писать функцию по подсчету суммы, потому что в queryset возвращает имена объектов, а не значения Integer, хотябы кортеж вывести (4,0,0) типо того.. От этого уже идти к тому, что при выборе ответа начисляется определенное кол-во баллов, чтобы написать функцию суммы баллов по всем ответам на вопросы.. Я даже пытался возвращать в модели int (self) self.score, но это не помогло.. хотя не совсем пойму как обратиться, ведь у меня модель Option где переменная score.. передается в другую модель через ForeignKey
рекомендации по репозитрию:
1) использовать poetry для упраления зависимостями (или хотябы pip freeze)
2) добавить .gitignore и добавить туда папку .idea
3) у вас то английский, то русский текст по коду. я бы порекомендовал писать только на английском, а для русского использовать переводы Django
4) избавиться от city_dropdown_list_options.html - правильнее это поместить в форму
5) сделать один шаблон для форм - шаблоны login и register - одинаковые, кроме текста в кнопке. правильнее было бы передавать его из view через контекст
6) сделать заполнение анкеты через ModelFormSet
7) тут у вас не передается id пациента. непонятно, к кому это будет относиться.
8) тут в кнопке нет ссылки
9) тут правильнее это поле назвать patient. name - всетаки больше подходит для CharField
10) тут я бы назвал поле "Национальность", а не "нация". и ChoiceNation - сделал бы в единственном числе.
11) тут название поля, по-моему, не верное. правильнее было бы назвать его question. всетаки вариант ответа ссылается на вопрос, а не на вариант ответа.
12) в модели Complient лучше убрать default. получается, что все они всегда будут ссылаться на первый объект. я не думаю, что такое поведение - то, что вам нужно
мелкие замечания:
/
/templates/
/. чтобы было drf4/amscsait/amscapp/templates/amscapp/
- если используется "date_of_birth", то правильнее было бы поле с датой регистрации назвать "date_of_registration". или наоборот "date_of_birth" -> "birth_date"
- в полях с nation не обязательно делать длину 10 - в бд будут храниться коды (RU, UA, GE, ...)
- хорошей практикой было бы для шаблонов делать путь
я бы делал так:
сделал бы 2 страницы: patient_info.html, куда в контекст передавал бы все Complaint, относящиеся к пациенту (если они есть, иначе - сообщение типа "Анкетирование еще не проводилось"). если ответы есть - показывать кнопку "изменить анекту", иначе - кнопку "провести анкетирование".
если вернуться к самому первому вопросу - тут у вас в поле score передаются вообще все ответы, при этом это - не поле.
Я чуть позже сделаю PR
drf4-master_updated.zip
Спасибо большое)
Я сделал на скорую руку (часа за полтора), так что верстка и прочее - могут быть кривыми, но за python код я уверен.
я буду рад, если вы обратите внимание на практики, которые я там использовал и которые указал выше
если будут вопросы по тому, как что работает - задавайте
хорошо