在Django模板中显示外键值

5 投票
2 回答
12486 浏览
提问于 2025-04-16 05:44

我遇到了一个问题。我刚开始学习python和django,大约两个月了。我有两个表,一个是项目(Project),另一个是状态(Status)。在状态表中,有一个外键指向项目表。我想在我的项目模板中显示外键的值(状态),而不是外键的地址。

这是我的models.py文件:

from django.db import models
from clients.models import Clients
from django.contrib.auth.models import User
from settings import STATUS_CHOICES

from django.db import models
from clients.models import Clients
from django.contrib.auth.models import User
from settings import STATUS_CHOICES

class Project(models.Model):
   client = models.ForeignKey(Clients, related_name='projects')
   created_by = models.ForeignKey(User, related_name='created_by')


#general information
   proj_name = models.CharField(max_length=255, verbose_name='Project Name')
   pre_quote = models.CharField(max_length=3,default='10-')
   quote = models.IntegerField(max_length=10, verbose_name='Quote #', unique=True)
   desc = models.TextField(verbose_name='Description')
   starts_on = models.DateField(verbose_name='Start Date')
   completed_on = models.DateField(verbose_name='Finished On')

   def __unicode__(self):
      return u'%s' % (self.proj_name)   


class Status(models.Model):
  project = models.ForeignKey(Project, related_name='status')
  value = models.CharField(max_length=20, choices=STATUS_CHOICES,                     verbose_name='Status')
  date_created= models.DateTimeField(auto_now=True) 

  def __unicode__(self):
     return self.value

  class Meta:
      verbose_name = ('Status')
      verbose_name_plural = ("Status")

这是我的views.py文件:

@login_required
 def addProject(request):
 if request.method == 'POST':
      form = AddSingleProjectForm(request.POST)
      if form.is_valid():
        project = form.save(commit=False)
        project.created_by = request.user  
        project.save()
        project.status.create(
                value = form.cleaned_data.get('status', None)
        )            
        return HttpResponseRedirect('/project/')
 else:
    form = AddSingleProjectForm()

 return render_to_response('project/addProject.html', {
 'form': form, 'user':request.user}, context_instance=RequestContext(request))

最后,这是我的模板:

{% if project_list %}
<table id="plist">
    <tr id="plist">
        <th>Quote #</th>
        <th>Customer</th>
        <th>Date</th>
        <th>Project Name</th>
        <th>Status</th>
        <th>Contact</th>
    </tr id="plist">
    {% for p in project_list %}
    <tr id="plist">
        <td><a href="/project/{{ p.id }}/view">{{ p.pre_quote }}{{ p.quote }}</a></td>
        <td>{{ p.client }}</td>
        <td>{{ p.starts_on }}</td>
        <td>{{ p.proj_name }}</td>
        <td>{{ p.status_set.select_related }}</td>
    <td>{{ p.created_by }}</td>
    </tr>
     {% endfor %}
    </table>

{% else %}
    <p>No projects available.</p>
{% endif %}

任何帮助都将非常感谢。谢谢!

2 个回答

3

在你的模型中,你把这个外键的相关名称定义为“status”。所以,现在你可以直接用“status”这个名字,而不需要用“_set”这种方式。

因为这是一个外键(多对一)字段,你不能简单地把这个字段当成只有一个值来显示。相反,你需要使用.all,这样可以返回一个包含所有指向这个对象的状态的查询集。然后你可以遍历这些状态。

如果你知道每个项目只会有一个状态,那你可以用一对一字段(OneToOne)来代替外键。

8

我猜你指的是这里:

<td>{{ p.status_set.select_related }}</td>

这个其实没什么用。select_related 是一个优化功能,它和实际获取或显示相关内容没有关系。如果你想做到这一点,你需要遍历 p.status_set.all 的结果。

撰写回答