所以我试图进入Python和Django的世界。来自PHP,很多事情都是相似的,但我很难弄清楚如何执行以下操作。
在PHP中,我会这样做:
$q = $this->db->query('SELECT * FROM data');
foreach ($q->result_array() as $key => $value) {
switch ($key) {
[...]
}
}
现在,我的问题是:如何在Django/Python中完成类似的事情?我有这个设置:
from index.models import Foo
def index(request):
datalist = Foo.objects.get(id=1)
然后呢?
注意:PHP 代码段中的查询甚至与 Django 代码段中的查询不匹配。PHP做一个SELECT * FROM data
但Python做一个SELECT * FROM data WHERE id = 1
,所以我将继续假设你打算Foo.objects.all()
而不是Foo.objects.get(id=1)
。如果您没有,那么请解决您的问题,并简单地删除下面代码片段的循环部分。此外,您应该为变量找到一个更好的名称,datalist
如果它只包含一个项目而不是顾名思义的列表,这最初让我感到困惑。
还没有真正清楚地描述您的目标是什么,但这里有一些可能符合您需求的选项:
for obj in datalist:
print "%s => %s" % (obj.id, obj)
。或者,如果要遍历所有对象的所有键值对:
for obj in datalist:
print "OBJECT %s" % obj.id
for field in Foo._meta.fields:
print " %s => %s" % (field.name, getattr(obj, field.name)
。或者,您可以使用django.forms.models.model_to_dict
帮助程序将对象转换为字典:
from django.forms.models import model_to_dict
for obj in datalist:
print "OBJECT %s" % obj.id
for key, value in model_to_dict(obj_as_dict).items():
print " %s => %s" % (key, value)