Django QuerySets 里的**kwargs: 动态创建ORM查询
Django的数据库API查询经常包含关键字参数。例如:
bob_stories = Story.objects.filter(title_contains='bob', subtitle_contains='bob', text_contains='bob',byline='bob')
下面展示如何按字典形式传递这些关键字参数:
bobargs = {'title_contains': 'bob', 'subtitle_contains': 'bob', 'text_contains': 'bob', 'byline_contains': 'bob'} bob_stories = Story.objects.filter(**bobargs)
这样,就可以动态的创建字典了:
bobargs = dict((f + '_contains', 'bob') for f in ('title', 'subtitle', 'text', 'byline')) bobstories = Story.objects.filter(**bobargs)
这样,就可以用这些技术来精简流水化查询中的多余部分,甚至有助于组装动态获取的过滤参数。