通过Python将Json数据导入MongoDB
问题描述
首先数据是以标准的json格式的文本。然后想要通过python脚本来导入Mongodb中。json
{ 'service': 'http', 'datetime': '2017-03-28 17:23:19', 'starttime': '1490692810', 'endtime': '1490692999', 'port': 80}{ 'service': 'ewall', 'datetime': '2017-03-28 17:23:19', 'starttime': '1490692810', 'endtime': '1490692999', 'port': 1328}
python部分代码:
with open(filen, ’r’) as f:while 1: try:jsonstr = f.readline().strip()# print jsonstr 可以输出整个json的内容if not jsonstr: breaktry: j = json.loads(jsonstr) #这里好像不处理的问题 except: continuejsonlist.append(j) except:break
请问这个情况要怎么解决呢?谢谢
问题解答
回答1:你这个问题是因为你这个不是标准的json格式,标准的格式应该是这样的
[{ 'service': 'http', 'datetime': '2017-03-28 17:23:19', 'starttime': '1490692810', 'endtime': '1490692999', 'port': 80},{ 'service': 'ewall', 'datetime': '2017-03-28 17:23:19', 'starttime': '1490692810', 'endtime': '1490692999', 'port': 1328}]
第二个你这个数据是按行读的,请告诉我你一行数据到底是什么样子的
回答2:@sheep3 的回答是对的。
如果你直接把JSON放MongoDB里你可以用mongoimport (https://docs.mongodb.com/manu...
你还想处理数据的话可以用这样的代码:
import jsonfilename = ’test.json’with open(filename, ’r’) as f: content = json.load(f)
如果JSON文件的内容比内存大你应该通过streaming方式把JSON文件打开。你可以用ijson包(https://pypi.python.org/pypi/...)。用法也比较简单:
import ijsonwith open(’test.json’) as fp: objects = ijson.items(fp, 'item') for object in objects:print(object)回答3:
@Christoph 的回答直接点名了更简单及优化的处理方案,学了一招
相关文章:
1. css3的背景图片属性有没有把图中这块蓝框区域(275*230)完整放在60*50区域?怎么写呢2. javascript - jQuery each 方法第三个参数args 如何解释?3. javascript - js中递归与for循环同时发生的时候,代码的执行顺序是怎样的?4. 如何分别在Windows下用Winform项模板+C#,在MacOSX下用Cocos Application项目模板+Objective-C实现一个制作游戏的空的黑窗口?5. android - 优酷的安卓及苹果app还在使用flash技术吗?6. javascript - 前端开发 本地静态文件频繁修改,预览时的缓存怎么解决?7. 新手 - Python 爬虫 问题 求助8. java - public <T> T findOne(T record) 这是什么意思9. mysql数据库每次查询是一条线程吗?10. python - linux怎么在每天的凌晨2点执行一次这个log.py文件
