2
我有2种型号,看起来像:获取/呈现一对多关系的最佳方式是什么?
class Entry(models.Model):
user = models.ForeignKey(User)
dataname = models.TextField()
datadesc = models.TextField()
timestamp = models.DateTimeField(auto_now=True)
class EntryFile(models.Model):
entry = models.ForeignKey(Entry)
datafile = models.FileField(upload_to="uploads/%Y/%m/%d/%H-%M-%S")
我想渲染所有的相关文件中的条目为特定用户。 我现在做这样的说法在我看来,以获取值:
entries = Entry.objects.filter(user=request.user).order_by("-timestamp")
files = {}
for entry in entries:
entryfiles = EntryFile.objects.filter(entry=entry)
files[entry] = entryfiles
return render_to_response("index.html", {'user': request.user, 'entries': entries, 'files': files, 'message': message})
但我不能/不知道如何在我的模板,这些数据的工作。这是我现在做的,但不工作:
{% for entry in entries %}
<td>{{ entry.datadesc }}</td>
<td><table>
{{ files.entry }}
{% for file in files.entry %}
<td>{{ file.datafile.name|split:"/"|last }}</td>
<td>{{ file.datafile.size|filesizeformat }}</td>
<td><a href="{{ object.datafile.url }}">download</a></td>
<td><a href="{% url main.views.delete object.id %}">delete</a></td>
{% endfor %}
</table></td>
{% endfor %}
任何人都可以告诉我,如果我考虑这样做的正确方法,然后如何在模板中访问这些数据?
谢谢!
它现在伟大的工作。谢谢! – 2009-06-01 05:27:57