我以为我理解了这一点,但我开始怀疑了!
如果您考虑repoze.catalog doco example:
from repoze.catalog.catalog import FileStorageCatalogFactory
from repoze.catalog.catalog import ConnectionManager
from repoze.catalog.indexes.field import CatalogFieldIndex
from repoze.catalog.indexes.text import CatalogTextIndex
factory = FileStorageCatalogFactory('catalog.db', 'mycatalog')
_initialized = False
def initialize_catalog():
global _initialized
if not _initialized:
# create a catalog
manager = ConnectionManager()
catalog = factory(manager)
# set up indexes
catalog['flavors'] = CatalogFieldIndex('flavor')
catalog['texts'] = CatalogTextIndex('text')
# commit the indexes
manager.commit()
manager.close()
_initialized = True
class Content(object):
def __init__(self, flavor, text):
self.flavor = flavor
self.text = text
if __name__ == '__main__':
initialize_catalog()
manager = ConnectionManager()
catalog = factory(manager)
content = {
1:Content('peach', 'i am so very very peachy'),
2:Content('pistachio', 'i am nutty'),
}
for docid, doc in content.items():
catalog.index_doc(docid, doc)
manager.commit()
这将向您展示如何为Content类的两个实例生成目录条目,但实际保存对象的正确机制是什么?
我开始有一个完全独立的ZODB数据库,我在其中存储了用于在repoze.catalog下编目的docid上的对象,但是当涉及到事务时,这不太令人满意,因为在添加对象时我必须发出目录和用于存储对象的ZODB数据库的提交。
我原以为我能够访问repoze.catalog结构中的ZODB目录并使用它来存储实际的对象,但是我很难找到如何做到这一点。
答案 0 :(得分:3)
像repoze.catalog
这样的目录用于索引内容,而不是存储内容。它的目的是通过索引该内容的某些方面,使查找您的内容(存储在其他地方)变得容易和高效。
给出的示例完全是独立的,并将其数据存储在单独的ZODB文件中。这是为了支持目录用于本身 存储在ZODB中的数据的用例。
但是,您可以将目录存储在存储内容的同一个ZODB中。您的内容对象应该遵循basic rules for persistent objects,但您可以自由地构建存储结构。
要为自己创建repoze.catalog
目录,而不是使用提供的FileStorageCatalogFactory
,只需实例化repoze.catalog.catalog.Catalog
:
from repoze.catalog.catalog import Catalog
if 'mycatalog' not in zodbroot:
zodbroot['mycatalog'] = Catalog()