使用Django访问多个值时的问题

1 投票
2 回答
570 浏览
提问于 2025-04-16 22:52

我刚开始学习Python,现在正在用Django做一个学生数据库应用。这个学生数据库应用需要显示学生的ID、名字、姓氏、科目名称和分数。每个学生有多个科目和对应的分数。现在我遇到的问题是,如何访问一个学生的多个科目和分数。

这是我的models.py文件:

class Person(models.Model):
    firstname=models.CharField(max_length=50)
    lastname=models.CharField(max_length=50)

    def __unicode__(self):
        return (self.firstname,self.lastname)


class Marksheet(models.Model):
    subname=models.CharField(max_length=50)
    marks=models.IntegerField(max_length=10)
    person=models.ForeignKey(Person)

    def __unicode__(self):
        return self.subname

这是我的views.py文件:

def add_page(request,page_name): # function for creating  the new records
    p1=None
    p2=None
    if request.method=='POST':
        p1=Person(firstname=request.POST['firstname'],lastname=request.POST['lastname'])
        p1.save()
        p2=Marksheet(subname=request.POST.getlist('subnames'),person=Person(person_id))
        p2.save()
    return render_to_response("add.html",{"page_name":page_name})

在创建记录时,我使用了下面的HTML表单……

模板文件 add.html:

<form method="post" action="/newdcl/{{page_name}}/add/" > {% csrf_token %}
    First name:  <input type="text" name="firstname" /> <br />
    Last name:  <input type="text" name="lastname" /> <br /> 
    Operating System  <input value="os" name="subnames" type="checkbox"><br />
    System Programming <input value="sp" name="subnames" type="checkbox"> <br />
    Maths <input value="maths" name="subnames" type="checkbox"> <br />        
    <input type="submit" value="save" >
</form> 

有没有人能帮我解决这个问题??

2 个回答

0

在我看来,应该通过在Person中使用多对多关系来实现这个功能。而表单应该定义为一个表单类,因为你的表单没有任何验证,而且你写了一些HTML,这些其实可以通过在模板中放一行代码来生成。我会这样做:

models.py

class Marksheet(models.Model):
    subname=models.CharField(max_length=50)
    marks=models.IntegerField(max_length=10)

    def __unicode__(self):
        return self.subname

class Person(models.Model):
    firstname=models.CharField(max_length=50)
    lastname=models.CharField(max_length=50)
    marksheets = models.ManyToManyField(Marksheet)

    def __unicode__(self):
        return (self.firstname,self.lastname)

forms.py

从models导入Person

class PersonForm(ModelForm):
    def __init__(self, *args, **kwargs):
        super(PersonForm, self).__init__(*args, **kwargs)
        # by default m2m relation is rendered with SelectMultiple widget -
        # - below line is changing it to checkbox list
        self.fields['marksheets'].widget = forms.CheckboxSelectMultiple()
    class Meta:
        model = Person

views.py

#inside your view function
if request.method == 'POST':
    form = PersonForm(request.POST)
    if form.is_valid():
        form.save()

# pass form to template in render_to_response

add.html

<form method="post" action="/newdcl/{{page_name}}/add/" > {% csrf_token %}
    {{ form }}
    <input type="submit" value="save" >
</form>
1

你的问题似乎出在你创建成绩单的方式上,你不能像那样把一堆值直接放到一个字段里。

p1=Person(firstname=request.POST['firstname'], 
          lastname=request.POST['lastname'])
p1.save()
for subname in request.POST.getlist('subnames'):
    new = MarkSheet(subname=subname, person=p1) 
        #no data for marks, must define it to be able to be blank/null
    new.save()

如果你打算在开始时不设置任何分数,你需要在你的models.py文件中的分数字段添加 blank=True, null=True

请查看 查询的制作表单

撰写回答