假设我在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模式表单动态创建表单
关于如何阅读模型的元数据的任何想法
答案 0 :(得分:3)
您可以获取模型的字段及其元数据:
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}
}
此方法的改进将包括字段元数据的黑名单,字段的白名单/黑名单,以及可能是未显示具有无值的元数据的布尔值。
答案 1 :(得分:1)
你应该能够通过内省得到那些信息,cf dir(Person._meta):你可以使用Person._meta.get_all_field_names()然后使用Person._meta.get_field_by_name(' first_name')来获取该字段并从中提取更多信息。