色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

通過Python將Json數據導入MongoDB

瀏覽:87日期:2022-08-15 13:00:38

問題描述

首先數據是以標準的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 的回答直接點名了更簡單及優化的處理方案,學了一招

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 日韩美女在线看免费观看 | 亚洲第5页 | 久久久这里只有精品加勒比 | 成年网站在线 | 国产精品黄网站 | 好看欧美视频高清va | 天堂中文资源在线8 | 97精品国产综合久久久久久欧美 | 成人午夜两性视频免费看 | 最近韩国日本免费免费版 | 男人在线天堂 | 色综合视频一区二区观看 | 亚洲高清视频免费 | 日韩三级中文 | 国产在线观看成人免费视频 | 黄色片亚洲 | 久久免费看视频 | 欧美一级aⅴ毛片 | 久久国产欧美另类久久久 | 欧美综合视频在线 | 欧美日韩亚洲综合久久久 | 成人精品视频 | 99精品这里只有精品高清视频 | 色拍拍噜噜噜aⅴ在线观看 色青青草原桃花久久综合 色婷婷91 | 亚洲欧洲一区二区三区久久 | 精品丝袜国产自在线拍亚洲 | 欧美视频在线观看网站 | 午夜日韩精品 | 欧美黄色xxx | 精品久久免费视频 | 亚洲午夜精品一区二区 | 久久国产香蕉 | 亚洲欧美网 | 久久99国产精品免费观看 | 大量真实偷拍情侣视频野战 | 亚洲影视一区二区 | 欧美一级毛片高清视频 | 日韩欧美国产精品 | 91成人免费视频 | 国产成人精品高清在线观看99 | 成人在线免费小视频 |