python實現(xiàn)合并多個list及合并多個django QuerySet的方法示例
本文實例講述了python實現(xiàn)合并多個list及合并多個django QuerySet的方法。分享給大家供大家參考,具體如下:
在用python或者django寫一些小工具應用的時候,有可能會遇到合并多個list到一個 list 的情況。單純從技術角度來說,處理起來沒什么難度,能想到的辦法很多,但我覺得有一個很簡單而且效率比較高的方法是我以前沒注意到的。那就是利用 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
輸出結果如下:
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相關內容感興趣的讀者可查看本站專題:《Python列表(list)操作技巧總結》、《Python編碼操作技巧總結》、《Python數(shù)據(jù)結構與算法教程》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》、《Python入門與進階經典教程》及《Python文件與目錄操作技巧匯總》
希望本文所述對大家Python程序設計有所幫助。
- Python Pandas pandas.read_sql_query函數(shù)實例用法分析
- python中pandas操作apply返回多列的實現(xiàn)
- python?pandas創(chuàng)建多層索引MultiIndex的6種方式
- Python+pandas編寫命令行腳本操作excel的tips詳情
- Python Pandas實現(xiàn)DataFrame合并的圖文教程
- Python的Django框架實現(xiàn)數(shù)據(jù)庫查詢(不返回QuerySet的方法)
- Python中類似于jquery的pyquery庫用法分析
- python?pandas?query的使用方法
相關文章
Python數(shù)據(jù)結構與算法中的隊列詳解(2)
這篇文章主要為大家詳細介紹了Python中的隊列,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
Python爬取OPGG上英雄聯(lián)盟英雄勝率及選取率信息的操作
這篇文章主要介紹了Python爬取OPGG上英雄聯(lián)盟英雄勝率及選取率信息的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04
python中小數(shù)點后取2位(四舍五入)及取2位(四舍五不入)的方法
這篇文章主要給大家介紹了python中小數(shù)點后取2位(四舍五入)及取2位(四舍五不入)的方法,在Python中取兩位小數(shù)的方法其實非常簡單,需要的朋友可以參考下2023-08-08
Python中實現(xiàn)從目錄中過濾出指定文件類型的文件
這篇文章主要介紹了Python中實現(xiàn)從目錄中過濾出指定文件類型的文件,本文是一篇學筆記,實例相對簡單,需要的朋友可以參考下2015-02-02
Python loguru日志庫之高效輸出控制臺日志和日志記錄
這篇文章主要介紹了python loguru日志庫之高效輸出控制臺日志和日志記錄的相關知識,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03

