服务器之家

服务器之家 > 正文

python实现合并多个list及合并多个django QuerySet的方法示例

时间:2021-07-09 14:57     来源/作者:轻舞肥羊

本文实例讲述了python实现合并多个list及合并多个django queryset的方法。分享给大家供大家参考,具体如下:

在用python或者django写一些小工具应用的时候,有可能会遇到合并多个list到一个 list 的情况。单纯从技术角度来说,处理起来没什么难度,能想到的办法很多,但我觉得有一个很简单而且效率比较高的方法是我以前没注意到的。那就是利用 chain 方法来合并多个list. 同样也可以用来合并django 的 queryset.

1. python用chain 来合并多个list

chain 是用c实现的,自然性能上比较可靠。下面看下基本用法:

?
1
2
3
4
5
6
7
8
9
#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 的话,是可以采用这种方式的.

?
1
2
3
4
5
6
7
8
9
#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 中去.

?
1
2
3
4
5
6
7
8
#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 然后再传输到某一个地方去的情况下,这样做很方便。

希望本文所述对大家python程序设计有所帮助。

原文链接:http://www.yihaomen.com/article/python/533.htm

标签:

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
2021德云社封箱演出完整版 2021年德云社封箱演出在线看
2021德云社封箱演出完整版 2021年德云社封箱演出在线看 2021-03-15
返回顶部