python - 如何从具有外键角度的模型中显示 Django admin 中的相关对象?

标签 python django django-admin

我有两个通过外键链接的 Django 模型:

class Author(models.Model):
    ...

class Book(models.Model):
    author = models.ForeignKey(Author)

请考虑下面的管理员示例(我想做相反的事情):

from django.contrib import admin
from my_app.models import Author, Book

class BookInline(admin.TabularInline):
    model = Book

class AuthorAdmin(admin.ModelAdmin):
    inlines = [
        BookInline,
    ]

admin.site.register(Author, AuthorAdmin)

在这个例子中,我们可以在管理员中看到所有作者,以及每个作者的书籍。

现在,我想反过来说。在管理中输入每本书,并在书籍详细信息中显示作者信息(可以是只读的)。我尝试了以下解决方案,但显然它没有用:

from django.contrib import admin
from my_app.models import Author, Book

class AuthorInline(admin.TabularInline):
    model = Author

class BookAdmin(admin.ModelAdmin):
    inlines = [
        AuthorInline,
    ]

admin.site.register(Book, BookAdmin)

Django 引发错误:

<class 'my_app.admin.AuthorInline'>: (admin.E202) 'my_app.Author' has no ForeignKey to 'my_app.Book'.

你知道怎么做吗?

更多上下文:

  • Django 1.11
  • 我想将 Book 和 Author 显示为 full readonly,这样 Book 的外键就不会被改变(至少不会从 admin 改变)

最佳答案

这是我的解决方案,也许不是最好的,但它确实有效! :)

我的想法是更改模板,因此能够以我想要的方式显示它。

管理员.py :

class BookAdmin(admin.ModelAdmin):
    ...
    change_form_template = 'admin/book_details.html'

    def change_view(self, request, object_id, form_url='', extra_context=None):
        extra_context = extra_context or {}
        extra_context['book'] = Book.objects.get(id=object_id)
        extra_context['author'] = extra_context['book'].author

        return super().change_view(request, object_id, form_url, extra_context=extra_context)

admin.site.register(Book, BookAdmin)

对于模板,我只是复制/粘贴 template change_form.html from the admin .

admin/book_details.html:

{% extends "admin/base_site.html" %}
{% load i18n admin_urls static admin_modify %}


{% block extrastyle %}{{ block.super }}<link rel="stylesheet" type="text/css" href="{% static "admin/css/forms.css" %}" />{% endblock %}

{% block coltype %}colM{% endblock %}

{% block breadcrumbs %}
<div class="breadcrumbs">
<a href="{% url 'admin:index' %}">{% trans 'Home' %}</a>
&rsaquo; <a href="{% url 'admin:app_list' app_label=opts.app_label %}">{{ opts.app_config.verbose_name }}</a>
&rsaquo; {% if has_change_permission %}<a href="{% url opts|admin_urlname:'changelist' %}">{{ opts.verbose_name_plural|capfirst }}</a>{% else %}{{ opts.verbose_name_plural|capfirst }}{% endif %}
&rsaquo; {% if add %}{% blocktrans with name=opts.verbose_name %}Add {{ name }}{% endblocktrans %}{% else %}{{ original|truncatewords:"18" }}{% endif %}
</div>
{% endblock %}


{% block content %}

# Display here want you want !

{% endblock %}

我查看了 Django 管理员的模板,以便能够以与默认模板显示相同的方式显示我的书和作者。所以我的用户不会被这个 View 打扰。

如果您找到更好的方法,请告诉我! :)

关于python - 如何从具有外键角度的模型中显示 Django admin 中的相关对象?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44718355/

相关文章:

python - 如何在 python 中使用 c 结构?

python - 如何在OpenERP中使用下拉字段?

django - 在 Django REST Framework 中向 get_queryset 请求添加参数

python - 登录 `rest-auth`后,如何返回更多信息?

python - Django Admin - 'ManyToManyField' 对象没有属性 'through'

python - Django 管理内联更改列表

python - 使用 PyGame 设计冒险游戏的正确方法是什么?

python - 如何在python中检测断开连接,而不发送数据

django - 构建 python 镜像时出现 Docker compose 问题,访问被拒绝或存储库不存在

python - Django Admin list_display 添加列【统计相关外键的记录】