2015-10-19 94 views
1

您好我有以下Models.py的Django:访问OneToOneField模板

class Question(models.Model): 
    user = models.ForeignKey(User) 
    article = models.ForeignKey(Article) 
    number = models.CharField("문제번호", max_length=10, null=True, blank=True) 
    q_type = models.CharField("문제유형", max_length=15) 
    question = models.TextField("문제내용") 
    answer = models.TextField("답안", null=True, blank=True) 
    reference = models.TextField("참고사항", null=True, blank=True) 

    def __str__(self): 
     return "%s번: %s" % (self.number, self.question) 

class Professor(models.Model): 
    question = models.OneToOneField(Question, null=True, blank=True, related_name="related_professor") 
    articles = models.ManyToManyField(Article, null=True, blank=True) 
    name = models.CharField("교수이름", max_length=20) 

    def __str__(self): 
     return "%s" % (self.name,) 

Views.py:

def read_q_table(request, board_id, article_id): 
    article = get_object_or_404(Article, id=article_id) 

    context = { 
     "boards" : Board.objects.all(), 
     "board_id" : board_id, 
     "questions" : Question.objects.all().order_by("number"), 
     "article" : article, 
     "professor" : Professor.objects.all() 
    } 
    return render(request, "q_table.html", context) 

模板:

{% if questions %} 
    {% for question in questions %} 
    <div class="list-group-item"> 
     <div class="row text-center"> 
      <div class="col-xs-2 col-md-2">{{ question.related_professor.name }}</div> 
     </div> 
    </div> 
    {% endfor %} 
{% else %} 

我想要的就是访问教授在模板中的名称字段。我已经将“问题”类对象的列表传递给模板,并且我想使用OneToOneField属性以某种方式访问​​模板中的相关教授名称。

根据Accessing Django OneToOneField in templates?,{{问题。 related_professor.name}}应该可以工作,但事实并非如此。谁能帮忙? 谢谢。

或者,首先保存教授数据可能会有问题。以下代码采用表单输入并提交它们以保存它们。

Professor.objects.get(name=professor).question = question_instance 
Professor.objects.get(name=professor).save() 

def submit_question中的这两行可能会引起眉毛,但我不确定。在这里,我试图获取相关教授实例并更新其问题字段(与Question类相关的OneToOneField)。

def submit_question(request, board_id, article_id): 
    article = get_object_or_404(Article, id= article_id) 

    try: 
     professor = request.POST["professor"].strip() 
     q_type = request.POST["q_type"].strip() 
     question = request.POST["question"].strip() 
     number = request.POST["number"].strip() 
     reference = request.POST["reference"].strip() 
     if request.POST['q_type']== "주관식": 
      answer = request.POST['d_answer'].strip() 
     else: 
      answer = request.POST['m_answer'].strip() 
    except KeyError: 
     request.session["error"] = "올바른 요청이 아닙니다." 
     return redirect("read_article", board_id, article_id) 

    if professor and q_type and question: 
     question_instance = article.question_set.create(q_type = q_type, question = question, user_id = request.user.id) 
     Professor.objects.get(name=professor).question = question_instance 
     Professor.objects.get(name=professor).save() 

    if number: 
     question_instance.number = number 

    if answer: 
     question_instance.answer = answer 

    if reference: 
     question_instance.reference = reference 

     question_instance.save() 

    else: 
     request.session["error"] = "출제교수, 문제유형 및 문제는 필수 입력 항목입니다." 
     return redirect("read_article", board_id, article_id) 
    return redirect("read_q_table", board_id, article_id) 
+0

你有没有试过'question.professor'? 'OneToOneField's有点特别.. – mccc

+0

@mccc是的。但这并不能解决问题。 – Bossam

+1

真的,你应该使用ModelForm来更新问题;这将摆脱整个代码的负担,使验证更好,并可能解决您的问题。 –

回答

2

这两条线是犯罪嫌疑人:

Professor.objects.get(name=professor).question = question_instance 
Professor.objects.get(name=professor).save() 

第二行将从数据库再次得到教授,这不会有,当你将它保存你的问题的实例连接了。试试这个:

prof = Professor.objects.get(name=professor) 
prof.question = question_instance 
prof.save()