V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐工具
RoboMongo
推荐书目
50 Tips and Tricks for MongoDB Developers
Related Blogs
Snail in a Turtleneck
billgreen1
V2EX  ›  MongoDB

mongodb 如何返回平的 dict?

  •  
  •   billgreen1 · 2016-01-26 12:46:35 +08:00 · 3863 次点击
    这是一个创建于 3252 天前的主题,其中的信息可能已经有所发展或是发生改变。

    我的查询结果一般如下:
    {
    'year':2015,
    ‘ a ’:1,
    'base': {'p1': 15}
    ....
    }

    目标是

    {
    'year':2015,
    ‘ a ’:1,
    'base.p1':15
    ....
    }

    我现在用的是自定义一个 flatten_dict 函数

    def flatten(d, parent_key='', sep='.'):
        """
        字典 flatten
        """
        items = []
        for k, v in d.items():
            new_key = parent_key + sep + k if parent_key else k
            if isinstance(v, MutableMapping):
                items.extend(flatten(v, new_key, sep=sep).items())
            else:
                items.append((new_key, v))
        return dict(items)
    

    但是太慢,因为大概有 3w+个这样的小的结果。 line_profile 显示

    isinstance(v, MutableMapping)
    

    占用了 60%的时间。

    我的想法是 mongodb 能否直接返回一个平的 dict ?
    因为查询的时候这样指定是可以的'base.p1':{'$gt':15}

    或者,通过修改 flatten 函数,使之快一点?

    4 条回复    2016-01-27 22:27:33 +08:00
    whahuzhihao
        1
    whahuzhihao  
       2016-01-26 14:14:04 +08:00
    什么叫平的 dict ?
    如果要求 base 字段不是数组 而是一个自定义键值对的话,可以用 aggregate 聚合方法里的 project 管道将结果重新格式化一遍 。如下:
    db.xxx.aggregate( {$project : { 'year':1,'a':1,'base.p1':'$base.p1'}} );
    whahuzhihao
        2
    whahuzhihao  
       2016-01-26 14:21:26 +08:00
    刚才试验了下。不能用'base.p1' : '$base.p1',得换个名字'base_p1':'$base.p1' 这样应该 ok
    billgreen1
        3
    billgreen1  
    OP
       2016-01-26 20:39:33 +08:00
    @whahuzhihao 感谢,我明天上班试试
    billgreen1
        4
    billgreen1  
    OP
       2016-01-27 22:27:33 +08:00
    @whahuzhihao 这正是我想要的,十分感谢。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2201 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 111ms · UTC 01:56 · PVG 09:56 · LAX 17:56 · JFK 20:56
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.