• 合并多个python list以及合并多个 django QuerySet 的方法


    在用python或者django写一些小工具应用的时候,有可能会遇到合并多个list到一个 list 的情况。单纯从技术角度来说,处理起来没什么难度,能想到的办法很多,但我觉得有一个很简单而且效率比较高的方法是我以前没注意到的。那就是利用 chain 方法来合并多个list. 同样也可以用来合并django 的 QuerySet.
    #coding:utf-8
    from itertools import chain
    a = [1,2,"aaa",{"name":"roy","age":100}]
    b = [3,4]
    c = [5,6]
    #items = a + b + c
    items = chain(a,b,c)
    for item in items:
        print item

    输出结果如下:

    1
    2
    aaa
    {'age': 100, 'name': 'roy'}
    3
    4
    5
    6

    由此可见可以很好的合并成功。

    2. 在Django 总用 chain 合并多个QuerySet.
    本身如果在Django中如果要合并同一个model的多个QuerySet 的话,是可以采用这种方式的.

    1 #coding:utf-8
    2 from itertools import chain
    3 from yihaomen.common.models import Article
    4 articles1 = Article.objects.order_by("autoid").filter(autoid__lt = 16).values('autoid','title')
    5 articles2 = Article.objects.filter(autoid = 30).values('autoid','title')
    6 articles = articles1 | articles2 # 注意这里采用的方式。如果 Model相同,而且没有用切片,并且字段一样时可以这样用
    7 print articles1
    8 print articles2
    9 print articles

    这样能很好的工作,但有些局限性,对于Django 来说很多情况下也够用了,合并到一个 QuerySet 中,然后返回到模板引擎中去处理。

    当然也可以用chain 来实现,用chain 来实现会更方便,也没那么多限制条件,即使是不同的MODEL中查询出来的数据,都可以很方便的合并到一个 list 中去.

    1 #coding:utf-8
    2 from itertools import chain
    3 from yihaomen.common.models import Article, UserID
    4 articles1 = Article.objects.order_by("autoid").filter(autoid__lt = 16).values('autoid','title')
    5 users = UserID.objects.all()
    6 items = chain(articles1, users)
    7 for item in items:
    8     print item

    这样做更方便,也很实用, 对于处理某些需要合并的list 然后再传输到某一个地方去的情况下,这样做很方便。

  • 相关阅读:
    java excel转pdf 工具类
    java word转pdf 工具类
    如何向数据库中添加TIMESTAMP(6)类型的数据
    IE浏览器 div或者其他容器的height属性无效 滚动条问题解决办法
    ComboBox赋值ItemsSource数据源的时候会触发SelectionChanged改变事件的解决办法
    devexpress chart 散点图加载并分组显示(可以自定义颜色 同组中的点颜色相同)
    myEclipse mybatis自动生成工具xml配置
    MySQL日志简介
    存储引擎简介
    索引介绍
  • 原文地址:https://www.cnblogs.com/blogofwyl/p/4296082.html
Copyright © 2020-2023  润新知