尊重原文做者,該文轉載於: 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