尊重原文做者,该文转载于: http://www.yihaomen.com/article/python/533.htmpython
在用python或者django写一些小工具应用的时候,有可能会遇到合并多个list到一个 list 的状况。单纯从技术角度来讲,处理起来没什么难度,能想到的办法不少,但我以为有一个很简单并且效率比较高的方法是我之前没注意到的。那就是利用 chain 方法来合并多个list. 一样也能够用来合并django 的 QuerySet.
1. python用chain 来合并多个list
chain 是用C实现的,天然性能上比较可靠。下面看下基本用法:django
#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 的话,是能够采用这种方式的.spa
#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 中去.code
#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 而后再传输到某一个地方去的状况下,这样作很方便。 htm