通過Python將Json數(shù)據(jù)導(dǎo)入MongoDB
問題描述
首先數(shù)據(jù)是以標(biāo)準(zhǔn)的json格式的文本。然后想要通過python腳本來導(dǎo)入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 可以輸出整個(gè)json的內(nèi)容if not jsonstr: breaktry: j = json.loads(jsonstr) #這里好像不處理的問題 except: continuejsonlist.append(j) except:break
請問這個(gè)情況要怎么解決呢?謝謝
問題解答
回答1:你這個(gè)問題是因?yàn)槟氵@個(gè)不是標(biāo)準(zhǔn)的json格式,標(biāo)準(zhǔn)的格式應(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}]
第二個(gè)你這個(gè)數(shù)據(jù)是按行讀的,請告訴我你一行數(shù)據(jù)到底是什么樣子的
回答2:@sheep3 的回答是對(duì)的。
如果你直接把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 的回答直接點(diǎn)名了更簡單及優(yōu)化的處理方案,學(xué)了一招
相關(guān)文章:
1. android - weex 項(xiàng)目createInstanceReferenceError: Vue is not defined2. PHPExcel表格導(dǎo)入數(shù)據(jù)庫怎么導(dǎo)入3. android - 哪位大神知道java后臺(tái)的api接口的對(duì)象傳到前端后輸入日期報(bào)錯(cuò),是什么情況?求大神指點(diǎn)4. javascript - 如圖,百度首頁,查看源代碼為什么什么都沒有?5. pdo 寫入到數(shù)據(jù)庫的內(nèi)容為中文的時(shí)候?qū)懭雭y碼6. vue2.0+webpack 如何使用bootstrap?7. PHP類封裝的插入數(shù)據(jù),總是插入不成功,返回false;8. html - 根據(jù)用戶id實(shí)現(xiàn)論壇用戶頭像顯示的最佳實(shí)現(xiàn)9. 前端 - 為什么CSS transform-origin 屬性在 Chrome 和 Safari 中得到完全不同的效果?10. docker綁定了nginx端口 外部訪問不到
