- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在编写一个用于保留不同资源的 Plone 日历模块。该模块具有一个日历,其事件存储在 Postgresql 中。每个日历都是一个存储在 ZODB 中的 Dexterity 对象。
为了在 Plone 和 Postgresql 之间建立联系,我很自然地求助于 Plone 对象的 uuid 属性。因此,Plone 中的每个 uuid 在 Postgresql 中充当外键,Postgresql 本身支持 uuid。
在我开始使用 Plone 4.1.4 之前的过去 6 个月里,这对我来说效果很好。有了它,引入了 plone.uuid 1.0.2,它将 uuid 的字符串表示从 uuids with 更改为 uuids without dashes。
此更改的问题是我无法再确定将在任何给定对象上使用哪种表示。 Plone 4.1.4 之前创建的对象包含与之后创建的对象不同格式的 uuid 字符串。
长话短说,为了确保我的代码适用于任何我希望能够使用 Python 的 uuid 类型进行搜索的 uuid 表示形式。
所以不要这样:
catalog.searchResults(UID='325dc47e-08f9-4fa1-bc18-3944a725adb4')
返回的结果与此不同:
catalog.searchResults(UID='325dc47e08f94fa1bc183944a725adb4')
我很乐意这样做:
from uuid import UUID
catalog.searchResults(UID=UUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))
这将等同于:
catalog.searchResults(UID=UUID('325dc47e08f94fa1bc183944a725adb4'))
有谁知道我怎样才能从 Plone 中的 uuid 表示中实现这种独立性?
最佳答案
您将不得不查询两种格式;一旦分配了 UID 字段,就不应更改它,真的。因此,您的选择是:
创建一个给定 UID 的方法返回一个包含虚线和非虚线版本的元组,然后用于查询目录:
def queryUID(UID):
if '-' in UID:
return (UID.replace('-', ''), UID)
return (UID, '-'.join([
UID[:8], UID[8:12], UID[12:16], UID[16:20], UID[20:]]))
有了这个方法,查询就变成了:
catalog.searchResults(UID=queryUID('325dc47e-08f9-4fa1-bc18-3944a725adb4'))
让你的数据库使用虚线版本,其中 Plone UID 有破折号,非虚线版本,旧的 Plone 内容仍然有一个没有破折号的 UID。换句话说,将 UID 视为不透明字符串。
Plone 中的 UID 在任何情况下都不会更改,因此您不必在生成虚线版本时搜索非虚线版本。一旦 UID 被分配给一个对象,它就永远不会改变,也永远不会获得破折号。
不推荐遍历您的 ZODB 并将所有不带破折号的 UID 替换为等效的破折号。这很可能会破坏通过 UID 链接到这些项目的任何其他内容。
关于python - 使用类型化 uuid 而不是字符串 uuid 查询 portal_catalog,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10137632/
在很长一段时间没有使用它之后,我又回到使用 Plone 了。我们已经使用 Plone 4.0.5 设置了一个 Intranet。我们已将大量文档(主要是文件)上传到内联网。 该站点是使用带有 ZEO
我正在文件夹内执行搜索。不幸的是,它还会检索根文件夹,我不希望这样。 例子如下。如果我有一个类似于下面的目录结构: RootFolder ... SubFolder1 ... SubF
我正在查询 portal_catalog 以使用 (UID, Title) 元组填充词汇表。该站点同时包含原型(prototype)和敏捷内容。 brains = portal_catalog.sea
我正在编写一个用于保留不同资源的 Plone 日历模块。该模块具有一个日历,其事件存储在 Postgresql 中。每个日历都是一个存储在 ZODB 中的 Dexterity 对象。 为了在 Plon
我是一名优秀的程序员,十分优秀!