【发布时间】:2018-10-15 23:39:45
【问题描述】:
我试图在我的代码购买遇到问题时尽可能少地重复自己。
我的代码是这样的
from .models import source
def myfunction():
if category1 == True:
types=5
b=[None]*types
for i in range(0, types):
b[i]=source.objects.all().filter(rowdata1='identifier', state=i)
elif category2 == True:
types=3
b=[None]*types
for i in range(0, types):
b[i]=source.objects.all().filter(rowdata2='identifier', state=i)
.
.
.
return result
但是我想做这样的事情:
def myfunction():
if category1 == True:
types=5
param='rowdata1'
elif category2 == True:
types=3
param='rowdata2'
b=[None]*types
for i in range(0, types):
b[i]=source.objects.all().filter(param='identifier', state=i)
.
.
.
return result
有没有办法使用字符串或其他结构作为过滤器值来访问 Django 中的模型?当我尝试我的示例 2 时,我得到一个字段错误,第一个有效。
工作建议:
def myfunction():
if category1 == True:
types=5
param='rowdata1'
elif category2 == True:
types=3
param='rowdata2'
b=[None]*types
for i in range(0, types):
b[i]=source.objects.all().filter(**{param:'identifier'}, state=i)
.
.
.
return result
【问题讨论】:
标签: python mysql django database model