次のような 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
お役に立てれば幸いです!