如何从django模型中提取元数据

时间:2015-04-28 04:16:47

标签: python django angularjs django-models metadata

假设我在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模式表单动态创建表单

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

2 个答案:

答案 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')来获取该字段并从中提取更多信息。