我正在尝试学习一些基本的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的明确说明..谢谢!
答案 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
不是数组!