gpt4 book ai didi

python - 我如何从 Django 模型中提取元数据

转载 作者:行者123 更新时间:2023-11-28 22:44:09 24 4
gpt4 key购买 nike

假设我在 django 中有这个模型

class Person(models.Model):
first_name = models.CharField(max_length=30)
last_name = models.CharField(max_length=30)

现在我想在 REST 中创建一个序列化程序以从模型中获取所有元数据。

就像生成的 JSON 应该包含

 //rough example
{
first_name: {max_length: 30},
last_name: {max_length:30}
}

我的目标是动态获取元数据,然后使用 angularJS 模式表单动态创建表单

关于如何读取模型的元数据的任何想法

最佳答案

您可以像这样获取模型的字段及其元数据:

def get_model_metadata(model_class, meta_whitelist=[]):
field_list = model_class._meta.fields
return_data = {}
for field in field_list:
field_name = field.name
field_meta = field.__dict__
return_meta = {}
for meta_name in field_meta:
if meta_name in meta_whitelist:
return_meta[meta_name] = field_meta[meta_name]
if len(return_meta) > 0:
return_data[field_name] = return_meta
return return_data

用法:

from django.contrib.auth.models import User
get_model_metadata(User, meta_whitelist=['max_length'])

返回:

{
'username': {'max_length': 30},
'first_name': {'max_length': 30},
'last_name': {'max_length': 30},
'is_active': {'max_length': None},
'email': {'max_length': 75},
'is_superuser': {'max_length': None},
'is_staff': {'max_length': None},
'last_login': {'max_length': None},
'password': {'max_length': 128},
u'id': {'max_length': None},
'date_joined': {'max_length': None}
}

对该方法的改进将包括字段元数据的黑名单、字段的白名单/黑名单,以及可能不显示具有 None 值的元数据的 bool 值。

关于python - 我如何从 Django 模型中提取元数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29910229/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com