I need to insert data from file.txt into new MongoDB database.collection using python.
.txt file contains data like:
a={
"_id" : "67a2c0e2e559fb56bf055502",
"field1" : "value1",
"field2" : ["value21","value22"],
"field3" : {
"_id" : "37a2c0e2e559fb56bf055502",
"subfield1" : "subvalue1"
}
};
b={
"_id" : "67a2c0e2e559fb56bf055503",
"field1" : "value1",
"field2" : ["value21","value22"],
"field3" : {
"_id" : "27a2c0e2e559fb56bf055503",
"subfield1" : "subvalue1"
}
};
c={....
};
I want to insert all documents if we say a=doc1, b=doc2, C=doc3, d...
I tried to split them in a list using l=split(read,';') and add it to Mongo with insert_many but I get this error
TypeError: document must be an instance of dict, bson.son.SON, bson.raw_bson.RawBSONDocument, or a type that inherits from collections.MutableMapping
is there any way to insert the data without creating json file? Thanks
Code
def insert():
client = pymongo.MongoClient(dbStringConnection)
db = client[dbName]
collectionR = db[dbCollection]
list1 = []
with open (file, 'r') as f:
reader= f.read()
#print (reader)
f.close()
reader= reader.replace('\n', '')
reader= reader.replace(' ','')
list1 = reader.split(';')
# print(list1[0])
list2={}
for i in range(len(lista)-1):
s=''
t=list1[i][0:1]
s=s+str(list1[i][2:len(list1[i])])
list2[t]=s
collectionR.insert_many(list2)