我正在编写一个用于保留不同资源的 Plone 日历模块。该模块具有一个日历,其事件存储在 Postgresql 中。每个日历都是存储在 ZODB 中的 Dexterity 对象。
为了在 Plone 和 Postgresql 之间建立联系,我自然而然地转向了 Plone 对象的 uuid 属性。因此,Plone 中的每个 uuid 都作为 Postgresql 中的外键,后者原生支持 uuid。
在我开始使用 Plone 4.1.4 之前,这对我来说在过去的 6 个月里效果很好。有了它,plone.uuid 1.0.2 被引入,它将 uuid 的字符串表示从 uuid 更改为不带破折号的 uuid 。
这种变化的问题是我不能再确定在任何给定对象上将使用哪种表示。在 Plone 4.1.4 之前创建的对象包含与之后创建的对象不同格式的 uuid 字符串。
长话短说,为了确保我的代码适用于任何 uuid 表示,我希望能够使用 Python 的 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'))
有谁知道我如何从 uuid 在 Plone 中的表示中实现这种独立性?