亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

通過Python將Json數據導入MongoDB

瀏覽:113日期: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 編程
相關文章:
主站蜘蛛池模板: 婷婷四房色播 | 亚洲色视频在线播放网站 | 欧洲亚洲欧美国产日本高清 | 亚洲欧美日韩不卡一区二区三区 | 奇米色88欧美一区二区 | 国产精品美女久久久久网站 | 宅男视频污在线看 | 最新更新国内自拍视频 | 拍拍拍无挡视频免费全程1000 | 亚洲综合色婷婷久久 | 制服丝袜自拍偷拍 | 国产欧美精品午夜在线播放 | 亚洲成人综合网站 | 婷婷久久综合九色综合98 | 黄色理论视频 | 国产精品拍自在线观看 | 巨大巨粗巨长 黑人长吊视频 | 美国一级大黄一片免费zzz | 免费黄色一级片 | 日本亚洲一区二区三区 | 国产欧美一区二区成人影院 | 国产人妖视频一区在线观看 | 亚洲欧美在线观看 | 国产制服丝袜在线 | 五月天婷婷精品视频 | 一级在线观看视频 | 亚洲精品网站在线观看不卡无广告 | 国产精品免费观看视频播放 | 97色伦色在线综合视频 | 妞干网在线观看 | 久久永久免费视频 | 亚洲欧美另类在线视频 | 日韩在线视频不卡一区二区三区 | 看中国国产一级毛片真人视频 | 久久va| 欧美最刺激好看的一级毛片 | 欧美一级毛片免费网站 | 亚洲精品久久婷婷爱久久婷婷 | 国产福利专区 | 一级大毛片| 欧美日比视频 |