gpt4 book ai didi

python - 使用类型化 uuid 而不是字符串 uuid 查询 portal_catalog

转载 作者:太空宇宙 更新时间:2023-11-03 15:23:55 28 4
gpt4 key购买 nike

我正在编写一个用于保留不同资源的 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 字段,就不应更改它,真的。因此,您的选择是:

  1. 创建一个给定 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'))
  2. 让你的数据库使用虚线版本,其中 Plone UID 有破折号,非虚线版本,旧的 Plone 内容仍然有一个没有破折号的 UID。换句话说,将 UID 视为不透明字符串。

    Plone 中的 UID 在任何情况下都不会更改,因此您不必在生成虚线版本时搜索非虚线版本。一旦 UID 被分配给一个对象,它就永远不会改变,也永远不会获得破折号。

  3. 不推荐遍历您的 ZODB 并将所有不带破折号的 UID 替换为等效的破折号。这很可能会破坏通过 UID 链接到这些项目的任何其他内容。

关于python - 使用类型化 uuid 而不是字符串 uuid 查询 portal_catalog,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10137632/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com