Collect from 网页模板
Modified by 追梦人物

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

尊重原文作者,该文转载于: http://www.yihaomen.com/article/python/533.htm

在用 python 或者 django 写一些小工具应用的时候,有可能会遇到合并多个 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

输出结果如下:

aaa
{'age': 100, 'name': 'roy'}

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

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 中,然后返回到模板引擎中去处理。
当然也可以用 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

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