MongoDB推送pymongo建议

时间:2016-01-03 03:29:08

标签: python mongodb pymongo

我正在尝试学习一些基本的MongoDB,并且我对如何使用$ push向我的文档添加更多数据感到困惑。这是我的代码:

from pymongo import MongoClient
client = MongoClient()
db = client.classes
collection = db.StudentsExample
student1 = {
         'name': 'adam',
         'year': 'sophomore',
         'age': 19,
         'class':[
                  {
                  'className': 'cse131',
                  'time': '2:30',
                  'finalGrade': 'A'
                  },
                  {
                  'className': 'cse240',
                  'time': '9:30',
                  'finalGrade': 'B'
                    }
                  ]
       } 
student2 = {
         'name': 'bob',
         'year': 'sophomore',
         'age': 19,
         'class':[
                  {
                  'className': 'cse131',
                  'time': '2:30',
                  'finalGrade': 'A'
                  },
                  {
                  'className': 'cse240',
                  'time': '9:30',
                  'finalGrade': 'B'
                    }
                  ]
       }

num = int(input("How many more classes?: "))

for x in range(0, num):
    classNameInput = str(input("Class name?: "))
    timeInput = str(input("Time of class?: "))
    finalGradeInput = str(input("Final grade in class?: "))
    db.StudentsExample.update(
        {'name': "adam"},
        {'$push': {'class.className': classNameInput, 'class.time': timeInput, 'class.finalGrade':finalGradeInput}}
        )



cursor = collection.find({})
for document in cursor: print(document)

我认为这样做是在student1中的类文档中添加另一个文档。例如,如果用户在提示时输入了:     班级名称:生物     时间:2:30     最终成绩:C

结果将是:

student1 = {
         'name': 'adam',
         'year': 'sophomore',
         'age': 19,
         'class':[
                  {
                  'className': 'cse131',
                  'time': '2:30',
                  'finalGrade': 'A'
                  },
                  {
                  'className': 'cse240',
                  'time': '9:30',
                  'finalGrade': 'B'
                    },
                  {
                   'className': 'bio
                   'time': 2:30
                   'finalGrade': 'C'
                   }
                  ]
       } 
student2 = {
         'name': 'bob',
         'year': 'sophomore',
         'age': 19,
         'class':[
                  {
                  'className': 'cse131',
                  'time': '2:30',
                  'finalGrade': 'A'
                  },
                  {
                  'className': 'cse240',
                  'time': '9:30',
                  'finalGrade': 'B'
                    }

                  ]
       }

我已经将这两个元素都插入到数据库中,所以即使插入方法不在此代码中,它们也在那里。

然而,它没有工作 - 它给出错误声明"不能使用part(class.time)来遍历元素({class:[{finalGrade:& #34; A",时间:" 2:30",className:" cse131"},{finalGrade:" B",时间:&#34 ; 9:30",className:" cse240"}]})

谁能告诉我我做错了什么?我无法找到关于如何使用push with python的明确说明..谢谢!

1 个答案:

答案 0 :(得分:0)

你几乎就在那里:

更改

{'$push': {'class.className': classNameInput, 'class.time': timeInput, 'class.finalGrade':finalGradeInput}

{'$push': {class: {'className': classNameInput, 'time': timeInput, 'finalGrade':finalGradeInput}}

一般格式是

{'$push': {<array to push to>: <value to push onto array>}}

如果我们查看您的代码,您可以看到您正在尝试将classNameInput推送到数组class.className。 Mongo然后出错,因为class.className不是数组!