在这种情况下,company.py 包含:
from django.utils import simplejson
class Company(db.Model):
name=db.StringProperty()
address=db.StringProperty()
def to_JSON():
d = dict([(p, unicode(getattr(self, p))) for p in self.properties()])
return simplejson.dumps(d)
office.py 包含:
from company import Company
class Office(db.Model):
name = db.StringProperty()
company = db.ReferenceProperty(Company, collection_name='offices')
模块 3 包含:
from company import Company
class Region(db.Model):
name = db.StringProperty()
company = db.ReferenceProperty(Company, collection_name='regions')
这是我需要做的一个简化示例,但应该很好地捕捉它......我需要 Company 能够将自己表达为 JSON 字符串,并且它不知道其他类(Office 和 Region)参考它。这适用于正常属性:
c = Company(name='A Company',address='123 Main St, New York, NY 12345')
c.put()
dallas = Office(name='Dallas',company=c)
dallas.put()
ny = Office(name='New York',company=c)
ny.put()
northeast = Region(name='NorthEast',company=c)
northeast.put()
southwest = Region(name='SouthWest',company=c)
southwest.put()
logging.info('Company as JSON: %s' % c.to_JSON())
我得到的输出是:
{"name": "A Company", "address": "123 Main St, New York, NY 12345"}
因此 properties() 包含预期的实体属性,但我还想包含来自关联对象的 ReferenceProperty 属性的反向引用。基本上我正在寻找的只是一个反向引用(collection_name)名称的列表,因为我知道它们代表查询,但我找不到任何方法来枚举反向引用名称本身。
请记住,此代码实际上并不代表真实代码,它已大大简化。现在这有效:
offices = getattr(company, 'offices')
所以我期待看到的是:
{"name": "A Company", "address": "123 Main St, New York, NY 12345",
"offices": "<db.Query object at 0x110e992d0>",
"regions": "<db.Query object at 0x110e99300>"
}
我实际上并不需要将反向引用“办公室”和“区域”包含在 properties() 枚举中,但是以某种方式检查它们的唯一性(例如,我不能在 Company 中也有 StringProperty命名为“办公室”),因此必须有一种方法来枚举它们。有人知道方法吗?