合並多個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


輸出結果如下:

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 中,然后返回到模板引擎中去處理。

當然也可以用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 然后再傳輸到某一個地方去的情況下,這樣做很方便。 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM