【问题标题】:pymongo - Invalid document cannot encode objectpymongo - 无效文档无法编码对象
【发布时间】:2019-07-30 23:57:52
【问题描述】:

我正在尝试使用欧几里得算法在给定图像的数据库中找到颜色最接近的图像(因为我并不真正关心距离,所以我省略了 sqrt)。数据库中的每个项目都包含字段rgb

这是我检索结果的代码:

r, g, b = utilities.get_avg_rgb(match_image.convert('RGB'))

res = self.database_collection.aggregate([
    {'$set': {
        'diff': {
            '$sum': [{'$pow': [{'$sub': ['$r', r]}, 2]},
                     {'$pow': [{'$sub': ['$g', g]}, 2]},
                     {'$pow': [{'$sub': ['$b', b]}, 2]}]
        }
    }},
    {'$sort': {'diff', 1}},
    {'$limit': 1}
])

但是,我收到以下错误:

<class 'tuple'>: (<class 'bson.errors.InvalidDocument'>, InvalidDocument("cannot encode object: {1, 'diff'}, of type: <class 'set'>"), <traceback object at 0x0F5483C8>)

我认为它说我正在尝试使用类 set 编码一个对象,但它不能这样做(?)但我找不到原因。

我可以知道为什么会发生这种情况以及如何解决它吗?谢谢

【问题讨论】:

  • 我相信 $sort 运算符采用&lt;field1&gt;: &lt;sort order&gt;,而您在其中有&lt;field1&gt;, &lt;sort order&gt;。试试{'$sort': {'diff': 1}}
  • @It'sNotMe 是的,解决了这个问题,但现在我得到了一个新的异常&lt;class 'tuple'&gt;: (&lt;class 'pymongo.errors.OperationFailure'&gt;, OperationFailure("Unrecognized pipeline stage name: '$set'"), &lt;traceback object at 0x0EBFFC60&gt;)
  • @It'sNotMe 非常感谢您为我看到这个!我将尝试从这里开始工作,您介意将其作为答案以便我接受吗?

标签: python mongodb pymongo


【解决方案1】:

我相信$sort 运算符采用&lt;field1&gt;: &lt;sort order&gt;,而您在其中有&lt;field1&gt;, &lt;sort order&gt;。试试{'$sort': {'diff': 1}}

另外,$set 是一个update operator,似乎在aggregation pipeline 中不受支持。

【讨论】:

    猜你喜欢
    • 2023-03-05
    • 2019-08-15
    • 2017-11-17
    • 2021-04-30
    • 2018-11-20
    • 2015-12-21
    • 1970-01-01
    • 2020-08-10
    • 2012-04-05
    相关资源
    最近更新 更多