午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

您的位置:首頁技術(shù)文章
文章詳情頁

通過Python將Json數(shù)據(jù)導入MongoDB

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

問題描述

首先數(shù)據(jù)是以標準的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的內(nèi)容if not jsonstr: breaktry: j = json.loads(jsonstr) #這里好像不處理的問題 except: continuejsonlist.append(j) except:break

請問這個情況要怎么解決呢?謝謝

問題解答

回答1:

你這個問題是因為你這個不是標準的json格式,標準的格式應(yīng)該是這樣的

[{ '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}]

第二個你這個數(shù)據(jù)是按行讀的,請告訴我你一行數(shù)據(jù)到底是什么樣子的

回答2:

@sheep3 的回答是對的。

如果你直接把JSON放MongoDB里你可以用mongoimport (https://docs.mongodb.com/manu...

你還想處理數(shù)據(jù)的話可以用這樣的代碼:

import jsonfilename = ’test.json’with open(filename, ’r’) as f: content = json.load(f)

如果JSON文件的內(nèi)容比內(nèi)存大你應(yīng)該通過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 的回答直接點名了更簡單及優(yōu)化的處理方案,學了一招

標簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 婷婷成人在线 | 亚洲精品一二三四区 | 狠狠插av | 亚洲免费在线视频 | 国产探花在线精品一区二区 | 天天爽天天做 | 国产91久久久 | 天天拍夜夜操 | 黄色片久久久 | 亚洲美女黄色 | 四虎影院在线免费观看 | 日本中文字幕久久 | 日韩欧美国产高清91 | 麻豆国产原创 | 午夜在线观看视频 | 国产在线视频在线观看 | av一道本 | 播放一级黄色片 | www.av.| 色网站免费观看 | 欧美成人午夜精品免费 | 草草影院国产第一页 | av一级在线 | 国产精品91在线观看 | 精品一区二区三区免费 | 亚洲色图综合区 | 男人天堂2021 | 久久精品一二三 | 国产成人精品综合久久久久99 | www亚洲国产 | 亚洲天堂精品在线 | 在线看成人片 | 久久久极品 | 国产成人精品久久久 | 国产在线视频一区二区 | 亚洲一级大片 | 亚洲精品一区在线观看 | 午夜影皖 | 欧美日韩中文字幕在线视频 | 日韩欧美无| 免费的三级网站 |