如何使用 pymongo 中对象列表中的值创建新的字段名称?

How do I create new field names using values from a list of objects in pymongo?

所以我在 mongo 数据库中有这种格式的记录(只是一个例子):

{
    _id: 1,
    name: "some name1",
    description: "some description1",
    parameters: [
        {
            name: "param name1",
            type: "param type1",
            default: "default value1"
        },
        {
            name: "param name2",
            type: "param type2",
            default: "default value2"
        }
    ]
   .
   .
   .
}

在我的程序中,我对记录执行此聚合:

{
    '$project': {
        'title': '$name,
        'description': True,
        'parameters': {
            'name': True,
            'parameter_type': '$parameters.type',
            'value': '$parameters.default'
        }
    }
}

尝试得到的结果:

{
    _id: 1,
    title: 'some name1',
    description: "some description1",
    parameters: [ 
        {
            name: "param name1",
            parameter_type: "param type1",
            value: "default value1"
        },
        {
            name: "param name2",
            parameter_type: "param type2",
            value: "default value2"
        }
    ]
 }

相反 我得到了:

{
    _id: 1,
    title: 'some name1',
    description: "some description1",
    parameters: [ 
        {
            name: "param name1",
            parameter_type: ["param type1", "param type2"],
            value: ["default value1", "default value2"]
        }
    ]
 }

我只想更改参数列表中对象的字段名称。我已经尝试查看 MongoDB 文档,但我无法找到一种方法来完成我需要的事情。

$unwind 从输入文档中解构一个数组字段并将它们按所需的投影分组。

演示 - https://mongoplayground.net/p/-pIPbSarfyx

db.collection.aggregate([
  {
    "$unwind": "$parameters"
  },
  {
    "$group": {
      "_id": "$_id",
      "name": {
        "$first": "$name"
      },
      "description": {
        "$first": "$description"
      },
      "parameters": {
        "$push": {
          "name": "$parameters.name",
          "parameter_type": "$parameters.type",
          "value": "$parameters.default"
        }
      },
      
    }
  }
])

$unwind

$group

$first

$push