搜索
您的当前位置:首页正文

合并多个pythonlist以及合并多个djangoQuerySet的方法

来源:星星旅游
合并多个pythonlist以及合并多个djangoQuerySet的⽅法

在⽤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 + citems = chain(a,b,c)for item in items: print item

输出结果如下:

12aaa

{'age': 100, 'name': 'roy'}3456

由此可见可以很好的合并成功。

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 articles1print articles2print 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 然后再传输到某⼀个地⽅去的情况下,这样做很⽅便。

因篇幅问题不能全部显示,请点此查看更多更全内容

Top