溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用python實現(xiàn)合并多個list及合并多個django QuerySet

發(fā)布時間:2021-04-07 10:17:53 來源:億速云 閱讀:188 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹了如何使用python實現(xiàn)合并多個list及合并多個django QuerySet,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

1. python用chain 來合并多個list

chain 是用C實現(xiàn)的,自然性能上比較可靠。下面看下基本用法:

#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

輸出結(jié)果如下:

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 來實現(xiàn),用chain 來實現(xiàn)會更方便,也沒那么多限制條件,即使是不同的MODEL中查詢出來的數(shù)據(jù),都可以很方便的合并到一個 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 然后再傳輸?shù)侥骋粋€地方去的情況下,這樣做很方便。

感謝你能夠認真閱讀完這篇文章,希望小編分享的“如何使用python實現(xiàn)合并多個list及合并多個django QuerySet”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業(yè)資訊頻道,更多相關知識等著你來學習!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI