@stayHARD

Как обработать динамический POST request Django?

Здравствуйте.
Приходит POST request в view такого вида:
<QueryDict: {u'med': [u'Aspirine'], u'dates': [u'2015-08-27,2015-08-29,2015-08-31'], u'unit1': [u'gram'], u'amount1': [u'1'], u'time1': [u'06:00:00'], u'course': [u'course name'], u'amount': [u'2'], u'med1': [u'Aspirine'], u'dates1': [u'2015-08-28,2015-08-30'], u'user': [u'test'], u'time': [u'08:00:00', u'12:00:00'], u'duration': [u'7'], u'csrfmiddlewaretoken': [u'9QSTwHmYkwuuQPSB3NbaR3L5S0v2jnpI'], u'start_date': [u'2015-08-27'], u'unit': [u'pil']}>


Нужно исходя из него сделать N полей в базе данных.
Для одного я делал вот так:
user = get_object_or_404(User, username = request.POST.get('user'))
		# create ONE new course
		new_course = Course(title = request.POST.get('course'), start_date = datetime.datetime.strptime(request.POST.get('start_date'), "%Y-%m-%d").date(), user = user)
		new_course.save()
		# create new days, count days = duration of the course
		start_delta = datetime.datetime.strptime(request.POST.get('start_date'), "%Y-%m-%d").date()
		end_delta = start_delta + timedelta(int(request.POST.get('duration')))
		delta = end_delta - start_delta
		for date in range(delta.days + 1):
			if str(start_delta + timedelta(days = date)) in request.POST.get('dates').split(','):
				med = get_object_or_404(Med, med = request.POST.get('med'))
				new_day = Day(date = start_delta + timedelta(days = date), course_id = new_course.id)
				new_day.save()
				new_preparate = Preparate(time = str(", ".join(request.POST.getlist('time'))), amount = request.POST.get('amount'), unit = request.POST.get('unit'), day_id = new_day.id, med_id = med.id)
				new_preparate.save()
			else:
				new_day = Day(date = start_delta + timedelta(days = date), course_id = new_course.id)
				new_day.save()

В данном куске кода я нахожу юзера, закрепляю за ним курс(1шт). Дальше закрепляю за курсом дни(их кол-во заранее неизвесно.(Их вводит юзер, например 7 - тогда будет создано 7 дней, которые будут закреплены за курсом.)
Дальше я создаю "препараты" и закрепляю их за днями которые юзер укажет в dates.

Как сделать тоже самое только для Nго количества полей.
name у полей формы med, med1, med2, med3....и так со всеми полями. Их кол-во неограничено.

Заранее спасибо за любые советы ;)
  • Вопрос задан
  • 449 просмотров
Решения вопроса 1
sim3x
@sim3x
На пхп стайл очень грустно смотреть в джанго

https://docs.djangoproject.com/en/1.8/topics/forms...
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы