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


    遇到合并多个list到一个 list 的情况。利用 chain 方法来合并多个list. 同样也可以用来合并django 的 QuerySet. 


    1. python用chain 来合并多个list。chain 是用C实现的,自然性能上比较可靠。下面看下基本用法:

    #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 的话,是可以采用这种方式的.
    #coding:utf-8
    from itertools import chain
    from yihaomen.common.models import Article
    articles1 = Article.objects.order_by("autoid").filter(autoid__lt = 16).values('autoid','title')
    articles2 = Article.objects.filter(autoid = 30).values('autoid','title')
    articles = articles1 | articles2 # 注意这里采用的方式。如果 Model相同,而且没有用切片,并且字段一样时可以这样用
    print articles1
    print articles2
    print articles
    这样能很好的工作,但有些局限性,对于Django 来说很多情况下也够用了,合并到一个 QuerySet 中,然后返回到模板引擎中去处理。

    3.用chain 来实现,用chain 来实现会更方便,也没那么多限制条件,即使是不同的MODEL中查询出来的数据,都可以很方便的合并到一个 list 中去.
    #coding:utf-8
    from itertools import chain
    from yihaomen.common.models import Article, UserID
    articles1 = Article.objects.order_by("autoid").filter(autoid__lt = 16).values('autoid','title')
    users = UserID.objects.all()
    items = chain(articles1, users)
    for item in items:
        print item
    原文地址:合并多个python list以及合并多个 django QuerySet 的方法, 感谢原作者分享。
  • 相关阅读:
    oracle基本语句
    SVM入门(六)线性分类器的求解——问题的转化,直观角度
    深入浅出KMeans算法
    SVM入门(三)线性分类器Part 2
    SVM入门(一)SVM的八股简介
    Hadoop源代码分析(五)
    用HTML5 Audio API开发游戏音乐
    Hadoop源代码分析(六)
    SVM入门(四)线性分类器的求解——问题的描述Part1
    SVM入门(二)线性分类器Part 1
  • 原文地址:https://www.cnblogs.com/liudefu/p/4433799.html
Copyright © 2020-2023  润新知