Django admin で json フィールドを表示する 質問する

Django admin で json フィールドを表示する 質問する

次のような Django モデルがあります。

class BodyHeight(models.Model):
    seats = models.ForeignKey(to=Seats)
    name = models.CharField(max_length=127, null=True, blank=True)
    key = models.CharField(max_length=100, null=True)
    data = models.TextField(null=True, blank=True)

    class Meta:
        verbose_name_plural = "Body heights"

    def __str__(self):
        return self.name

そして、データ フィールドには、次のように json データを保存します。

{"url": "https://some_url=/BE?category=COMMERCIAL, "images": ["url_to_some_image"]}

そして、Django 管理パネルにはそのフィールドの URL のみを表示したいと思います。

今私が持っています:

class BodyHeightAdmin(admin.ModelAdmin):
    search_fields = ('name', )
    list_display = ('id', 'name', 'key', )
    list_display_links = ('id', 'name', 'key', )

admin.site.register(BodyHeight, BodyHeightAdmin)

それはデータ フィールドなしです。dataフィールドを追加するとlist_display、JSON 全体 (醜い形式) が表示されますが、必要なのは だけですurl

それをどうやって行うのか、何かアイデアはありますか?

ベストアンサー1

Django Admin (Django>=3.1) で JSONField の基本的なフォーマットを追加するための私のソリューション:

import json
import logging

from django.db.models import JSONField 
from django.contrib import admin
from django.forms import widgets


logger = logging.getLogger(__name__)


class PrettyJSONWidget(widgets.Textarea):

    def format_value(self, value):
        try:
            value = json.dumps(json.loads(value), indent=2, sort_keys=True)
            # these lines will try to adjust size of TextArea to fit to content
            row_lengths = [len(r) for r in value.split('\n')]
            self.attrs['rows'] = min(max(len(row_lengths) + 2, 10), 30)
            self.attrs['cols'] = min(max(max(row_lengths) + 2, 40), 120)
            return value
        except Exception as e:
            logger.warning("Error while formatting JSON: {}".format(e))
            return super(PrettyJSONWidget, self).format_value(value)


class JsonAdmin(admin.ModelAdmin):
    formfield_overrides = {
        JSONField: {'widget': PrettyJSONWidget}
    }

使用法:

admin.site.register(models.MyModel, JsonAdmin)

Django < 3.1 の場合は、次のように JSONField をインポートする必要があります。

from django.contrib.postgres.fields import JSONField 

お役に立てれば幸いです!

おすすめ記事