我正在使用 django-transmeta(无法让其他任何东西与 django 1.2.5 一起更好地工作)它在表中创建多个列,如:content_en、content_es、content_it
在实现 i18n 之前我有:
items = Items.objects.filter(categories__slug=slug)
现在 category.slug 已国际化,因此我有“category.slug_en”、“category.slug_es”、“category.slug_it”等。
所以我想到了:
from django.db.models import Q
from django.utils.translation import get_language
current_lang = get_language()
queryset = {
'en': Q(categories__slug_en__contains=slug),
'es': Q(categories__slug_es__contains=slug),
'it': Q(categories__slug_it__contains=slug),
}
items = Items.objects.filter(queryset[current_lang])
但如果我这样做,每当我需要添加一种新语言时,我将不得不更改代码,当然我不想这样做。
所以我做了:
from django.db.models import Q
from django.utils.translation import get_language
current_lang = get_language()
var = 'Q(categories__slug_%s=slug)' % current_lang
queryset = eval(var)
items = Items.objects.filter(queryset)
但在这种情况下,我使用的是 eval(),这当然是 evil() 的同义词,最好避免使用它。
所以我想知道:是否有更好的方法来做到这一点?
非常感谢!
最佳答案
尝试
q = Q(**{"categories__slug_" + current_lang + "__contains": slug})
items = Items.objects.filter(q)
关于python - 在 QuerySets (Python/Django) 中翻译关键字参数时比 eval() 更好的方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5092336/