将带有数字键的数据插入 mongodb 时出错(python 字典中的 GPS 数据)
Posted
技术标签:
【中文标题】将带有数字键的数据插入 mongodb 时出错(python 字典中的 GPS 数据)【英文标题】:Error when Inserting data with numerical keys into mongodb (GPS data in a python dictionary) 【发布时间】:2020-02-04 01:27:06 【问题描述】:我正在尝试使用pymongo
将一些图像元数据存储到MongoDB
。但是插入时出现错误。
#Data in Dictionary
gps = 'GPSInfo': 1: 'N', 2: ((38, 1), (54, 1), (3540, 100)), 3: 'E', 4: ((1, 1), (26, 1), (1920, 100)), 5: b'\x00', 6: (0, 1), 7: ((11, 1), (7, 1), (47, 1)), 16: 'T', 17: (5338, 65), 29: '2011:09:04'
import pymongo
mng_client = pymongo.MongoClient('localhost', 27017)
mng_db = mng_client['pic_db']
collection_name = 'pic_audit_log2'
db_cm = mng_db[collection_name]
# Insert data from a dictionary
db_cm.remove()
db_cm.insert(gps)
错误
InvalidDocument: documents must have only string keys, key was 1
我是否必须将所有数字字典键更改为字符串? 当我这样做时它会起作用。
d = str(a):str(c):d for c,d in b.items() if isinstance(b,dict) else b for a,b in gps.items()
# Insert data from dictionary
db_cm.remove()
db_cm.insert(d)
还有其他更好的选择吗?
【问题讨论】:
【参考方案1】:在插入数据时,mongo shell 会为您将整数转换为字符串,但 pymongo 不会。您的解决方法可能与任何解决方法一样好。
【讨论】:
以上是关于将带有数字键的数据插入 mongodb 时出错(python 字典中的 GPS 数据)的主要内容,如果未能解决你的问题,请参考以下文章
我在 PHP 中插入带有地理空间数据的 Mongodb 记录时遇到问题