继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

python 生成内嵌式字典(dict)-案例从python提取内嵌json写入mongodb

慕斯卡3302699
关注TA
已关注
手记 271
粉丝 58
获赞 314

从mongo查询利用python 读写如新的集合

import traceback,from gaode_hotel.conn_mongodb import conn_mongodbimport pandas as pdclass extra_yunnan_hotel(object):
    def get_yunnan_hotel(self):
        #查询
        db_1 = conn_mongodb("gaode_pois","gaode_pois_hotel_beijing")        #插入
        db_2 = conn_mongodb("gaode_pois","gaode_pois_hotel_beijing_extra_mid010000")
        data=db_1.db_find({}).limit(10)        for x in data:        #创建字典
            dic={}        #创建嵌套字典
            dic.setdefault('geo',{})["loc"]={}            try:
                dic["_id"]=x["id"]
                dic["name"]=x["name"]                # dic["loction"]=x["location"]
                dic.setdefault('geo',{})["loc"]=x["location"]
                dic["lng"]=x["location"].split(',')[0]
                dic["lat"]=x["location"].split(',')[1]              
            except:
                print(traceback.print_exc())
start=extra_yunnan_hotel()
start.get_yunnan_hotel()

结果成功:
https://img4.mukewang.com/5b3df6f30001f10705810287.jpg
更多的字典镶嵌
目的:生成{1: {‘errors’: {0: ‘d:\helloworld’, 1: ‘d:\dict’}, ‘os’: ‘windows’, ‘type’: 2}}这样的多层嵌套的数据。

d1={} d1.setdefault(1,{})[errors]={}

用同样的方式设置下一侧的嵌套

temp = d1[1] 
temp.setdefault(‘errors’,{})[error_len]=’d:\helloworld’

d1.setdefault(key,{})[‘os’]=’windows’

d1.setdefault(key,{})[‘type’]=2

OK,这样就可以生成想要的格式的数据了。


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP