在Django模板中显示外键值
我遇到了一个问题。我刚开始学习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
的结果。