本文實例講述了python實現(xiàn)合并多個list及合并多個django QuerySet的方法。分享給大家供大家參考,具體如下:
在用python或者django寫一些小工具應(yīng)用的時候,有可能會遇到合并多個list到一個 list 的情況。單純從技術(shù)角度來說,處理起來沒什么難度,能想到的辦法很多,但我覺得有一個很簡單而且效率比較高的方法是我以前沒注意到的。那就是利用 chain 方法來合并多個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 中,然后返回到模板引擎中去處理。
當(dāng)然也可以用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相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python列表(list)操作技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進(jìn)階經(jīng)典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設(shè)計有所幫助。
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯(lián)系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
