- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我最近在 Django 中发现了大量 JSON 序列化各种对象的代码。不幸的是,代码在遇到某些类型的模型时会抛出 AttributeError。
这是我试图诊断和解决的错误和回溯:
AttributeError at /serial/
'NoneType' object has no attribute '_meta'
Request Method: GET
Request URL: http://127.0.0.1:8000/serial/
Django Version: 1.2.5
Exception Type: AttributeError
Exception Value:
'NoneType' object has no attribute '_meta'
Exception Location: /Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py in handle_m2m_field, line 183
Python Executable: /usr/bin/python
Python Version: 2.6.7
Python Path: ['/Users/jphill/apps/d_projects/smartgoal', '/Library/Python/2.6/site-packages/setuptools-0.6c11-py2.6.egg', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python26.zip', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/plat-darwin', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/plat-mac', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/plat-mac/lib-scriptpackages', '/System/Library/Frameworks/Python.framework/Versions/2.6/Extras/lib/python', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/lib-tk', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/lib-old', '/System/Library/Frameworks/Python.framework/Versions/2.6/lib/python2.6/lib-dynload', '/Library/Python/2.6/site-packages', '/System/Library/Frameworks/Python.framework/Versions/2.6/Extras/lib/python/PyObjC']
Server time: Fri, 11 Nov 2011 23:08:13 -0500
Environment:
Request Method: GET
Request URL: http://127.0.0.1:8000/serial/
Django Version: 1.2.5
Python Version: 2.6.7
Installed Applications:
['django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.admin',
'django.contrib.admindocs',
'hq']
Installed Middleware:
('django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware')
Traceback:
File "/Library/Python/2.6/site-packages/django/core/handlers/base.py" in get_response
100. response = callback(request, *callback_args, **callback_kwargs)
File "/Users/jphill/apps/d_projects/smartgoal/hq/views.py" in serial
164. return json_response_from(Task.objects.all())
File "/Users/jphill/apps/d_projects/smartgoal/hq/views.py" in json_response_from
88. return HttpResponse(jsonSerializer.serialize(response, ), mimetype='application/json')
File "/Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py" in serialize
34. self.handle_object(obj)
File "/Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py" in handle_object
75. self.handle_queryset(object)
File "/Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py" in handle_queryset
138. self.handle_model(mod)
File "/Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py" in handle_model
128. self.handle_m2m_field(mod, field)
File "/Users/jphill/apps/d_projects/smartgoal/../smartgoal/hq/custom_serializer.py" in handle_m2m_field
183. if field.rel.through._meta.auto_created:
Exception Type: AttributeError at /serial/
Exception Value: 'NoneType' object has no attribute '_meta'
from io import StringIO
from django.db.models import Model
from django.db.models.query import QuerySet
from django.utils.encoding import smart_unicode
from django.utils.simplejson import dumps
class UnableToSerializeError(Exception):
""" Error for not implemented classes """
def __init__(self, value):
self.value = value
Exception.__init__(self)
def __str__(self):
return repr(self.value)
class JSONSerializer():
boolean_fields = ['BooleanField', 'NullBooleanField']
datetime_fields = ['DatetimeField', 'DateField', 'TimeField']
number_fields = ['IntegerField', 'AutoField', 'DecimalField', 'FloatField', 'PositiveSmallIntegerField']
def serialize(self, obj, **options):
self.options = options
self.stream = options.pop("stream", StringIO())
self.selectedFields = options.pop("fields", None)
self.ignoredFields = options.pop("ignored", None)
self.use_natural_keys = options.pop("use_natural_keys", False)
self.currentLoc = ''
self.level = 0
self.start_serialization()
self.handle_object(obj)
self.end_serialization()
return self.getvalue()
def get_string_value(self, obj, field):
"""Convert a field's value to a string."""
return smart_unicode(field.value_to_string(obj))
def start_serialization(self):
"""Called when serializing of the queryset starts."""
pass
def end_serialization(self):
"""Called when serializing of the queryset ends."""
pass
def start_array(self):
"""Called when serializing of an array starts."""
self.stream.write(u'[')
def end_array(self):
"""Called when serializing of an array ends."""
self.stream.write(u']')
def start_object(self):
"""Called when serializing of an object starts."""
self.stream.write(u'{')
def end_object(self):
"""Called when serializing of an object ends."""
self.stream.write(u'}')
def handle_object(self, object):
""" Called to handle everything, looks for the correct handling """
if isinstance(object, dict):
self.handle_dictionary(object)
elif isinstance(object, list):
self.handle_list(object)
elif isinstance(object, Model):
self.handle_model(object)
elif isinstance(object, QuerySet):
self.handle_queryset(object)
elif isinstance(object, bool):
self.handle_simple(object)
elif isinstance(object, int) or isinstance(object, float) or isinstance(object, long):
self.handle_simple(object)
elif isinstance(object, basestring):
self.handle_simple(object)
else:
raise UnableToSerializeError(type(object))
def handle_dictionary(self, d):
"""Called to handle a Dictionary"""
i = 0
self.start_object()
for key, value in d.iteritems():
self.currentLoc += key+'.'
#self.stream.write(unicode(self.currentLoc))
i += 1
self.handle_simple(key)
self.stream.write(u': ')
self.handle_object(value)
if i != len(d):
self.stream.write(u', ')
self.currentLoc = self.currentLoc[0:(len(self.currentLoc)-len(key)-1)]
self.end_object()
def handle_list(self, l):
"""Called to handle a list"""
self.start_array()
for value in l:
self.handle_object(value)
if l.index(value) != len(l) -1:
self.stream.write(u', ')
self.end_array()
def handle_model(self, mod):
"""Called to handle a django Model"""
self.start_object()
for field in mod._meta.local_fields:
if field.rel is None:
if self.selectedFields is None or field.attname in self.selectedFields or field.attname:
if self.ignoredFields is None or self.currentLoc + field.attname not in self.ignoredFields:
self.handle_field(mod, field)
else:
if self.selectedFields is None or field.attname[:-3] in self.selectedFields:
if self.ignoredFields is None or self.currentLoc + field.attname[:-3] not in self.ignoredFields:
self.handle_fk_field(mod, field)
for field in mod._meta.many_to_many:
if self.selectedFields is None or field.attname in self.selectedFields:
if self.ignoredFields is None or self.currentLoc + field.attname not in self.ignoredFields:
self.handle_m2m_field(mod, field)
self.stream.seek(self.stream.tell()-2)
self.end_object()
def handle_queryset(self, queryset):
"""Called to handle a django queryset"""
self.start_array()
it = 0
for mod in queryset:
it += 1
self.handle_model(mod)
if queryset.count() != it:
self.stream.write(u', ')
self.end_array()
def handle_field(self, mod, field):
"""Called to handle each individual (non-relational) field on an object."""
self.handle_simple(field.name)
if field.get_internal_type() in self.boolean_fields:
if field.value_to_string(mod) == 'True':
self.stream.write(u': true')
elif field.value_to_string(mod) == 'False':
self.stream.write(u': false')
else:
self.stream.write(u': undefined')
else:
self.stream.write(u': ')
self.handle_simple(field.value_to_string(mod))
self.stream.write(u', ')
def handle_fk_field(self, mod, field):
"""Called to handle a ForeignKey field."""
related = getattr(mod, field.name)
if related is not None:
if field.rel.field_name == related._meta.pk.name:
# Related to remote object via primary key
pk = related._get_pk_val()
else:
# Related to remote object via other field
pk = getattr(related, field.rel.field_name)
d = {
'pk': pk,
}
if self.use_natural_keys and hasattr(related, 'natural_key'):
d.update({'natural_key': related.natural_key()})
if type(d['pk']) == str and d['pk'].isdigit():
d.update({'pk': int(d['pk'])})
self.handle_simple(field.name)
self.stream.write(u': ')
self.handle_object(d)
self.stream.write(u', ')
def handle_m2m_field(self, mod, field):
"""Called to handle a ManyToManyField."""
if field.rel.through._meta.auto_created:
self.handle_simple(field.name)
self.stream.write(u': ')
self.start_array()
hasRelationships = False
for relobj in getattr(mod, field.name).iterator():
hasRelationships = True
pk = relobj._get_pk_val()
d = {
'pk': pk,
}
if self.use_natural_keys and hasattr(relobj, 'natural_key'):
d.update({'natural_key': relobj.natural_key()})
if type(d['pk']) == str and d['pk'].isdigit():
d.update({'pk': int(d['pk'])})
self.handle_simple(d)
self.stream.write(u', ')
if hasRelationships:
self.stream.seek(self.stream.tell()-2)
self.end_array()
self.stream.write(u', ')
def handle_simple(self, simple):
""" Called to handle values that can be handled via simplejson """
self.stream.write(unicode(dumps(simple)))
def getvalue(self):
"""Return the fully serialized object (or None if the output stream is not seekable).sss """
if callable(getattr(self.stream, 'getvalue', None)):
return self.stream.getvalue()
class Task(models.Model):
"""
Model used for tracking tasks
"""
PRIORITY_CHOICES = (
('0', 'None'),
('1', 'High'),
('2', 'Medium'),
('3', 'Low'),
)
name = models.CharField(max_length=255)
completed = models.BooleanField(default=False)
hidden = models.BooleanField(default=False)
timestamp = models.DateField(auto_now=True)
priority = models.CharField(default=0, max_length=1, choices=PRIORITY_CHOICES)
creator = models.ForeignKey(User, related_name="created_task")
# optional
owner = models.ForeignKey(User, related_name="owned_task", blank=True, null=True)
goal = models.ForeignKey('Goal', blank=True, null=True)
reminder = models.DateTimeField(blank=True, null=True)
note = models.TextField(blank=True)
started = models.BooleanField(default=False, blank=True)
activities = generic.GenericRelation('Activity')
def serial(request):
return json_response_from(Task.objects.all())
def json_response_from(response):
jsonSerializer = JSONSerializer()
return HttpResponse(jsonSerializer.serialize(response, use_natural_keys=True), mimetype='application/json')
最佳答案
我的猜测是 GenericRelation
的问题.这是一个相当新的字段类型,可能在编写序列化代码时还没有实现。
GenericRelation 字段在内部使用 ManyToMany 关系,并且可能以它们未定义 field.rel.through
的方式使用。对象。这会导致您的情况出现错误。您可以通过添加一些日志来查看哪个字段导致了问题来验证这一点。
要解决它,您可以更多地查看 GenericRelations
并修改序列化代码以支持它们或使用其他一些支持 GenericRelations
的序列化技术.
来自 GenericRelation
的 Django 源代码的剪辑类(class):
def get_internal_type(self):
return "ManyToManyField"
关于Django 序列化程序错误 : 'NoneType' object has no attribute '_meta' ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8102523/
我是 C 语言新手,我编写了这个 C 程序,让用户输入一年中的某一天,作为返回,程序将输出月份以及该月的哪一天。该程序运行良好,但我现在想简化该程序。我知道我需要一个循环,但我不知道如何去做。这是程序
我一直在努力找出我的代码有什么问题。这个想法是创建一个小的画图程序,并有红色、绿色、蓝色和清除按钮。我有我能想到的一切让它工作,但无法弄清楚代码有什么问题。程序打开,然后立即关闭。 import ja
我想安装screen,但是接下来我应该做什么? $ brew search screen imgur-screenshot screen
我有一个在服务器端工作的 UDP 套接字应用程序。为了测试服务器端,我编写了一个简单的 python 客户端程序,它发送消息“hello world how are you”。服务器随后应接收消息,将
我有一个 shell 脚本,它运行一个 Python 程序来预处理一些数据,然后运行一个 R 程序来执行一些长时间运行的任务。我正在学习使用 Docker 并且我一直在运行 FROM r-base:l
在 Linux 中。我有一个 c 程序,它读取一个 2048 字节的文本文件作为输入。我想从 Python 脚本启动 c 程序。我希望 Python 脚本将文本字符串作为参数传递给 c 程序,而不是将
对于一个类,我被要求编写一个 VHDL 程序,该程序接受两个整数输入 A 和 B,并用 A+B 替换 A,用 A-B 替换 B。我编写了以下程序和测试平台。它完成了实现和行为语法检查,但它不会模拟。尽
module Algorithm where import System.Random import Data.Maybe import Data.List type Atom = String ty
我想找到两个以上数字的最小公倍数 求给定N个数的最小公倍数的C++程序 最佳答案 int lcm(int a, int b) { return (a/gcd(a,b))*b; } 对于gcd,请查看
这个程序有错误。谁能解决这个问题? Error is :TempRecord already defines a member called 'this' with the same paramete
当我运行下面的程序时,我在 str1 和 str2 中得到了垃圾值。所以 #include #include #include using namespace std; int main() {
这是我的作业: 一对刚出生的兔子(一公一母)被放在田里。兔子在一个月大时可以交配,因此在第二个月的月底,每对兔子都会生出两对新兔子,然后死去。 注:在第0个月,有0对兔子。第 1 个月,有 1 对兔子
我编写了一个程序,通过对字母使用 switch 命令将十进制字符串转换为十六进制,但是如果我使用 char,该程序无法正常工作!没有 switch 我无法处理 9 以上的数字。我希望你能理解我,因为我
我是 C++ 新手(虽然我有一些 C 语言经验)和 MySQL,我正在尝试制作一个从 MySQL 读取数据库的程序,我一直在关注这个 tutorial但当我尝试“构建”解决方案时出现错误。 (我正在使
仍然是一个初学者,只是尝试使用 swift 中的一些基本函数。 有人能告诉我这段代码有什么问题吗? import UIKit var guessInt: Int var randomNum = arc
我正在用 C++11 编写一个函数,它采用 constant1 + constant2 形式的表达式并将它们折叠起来。 constant1 和 constant2 存储在 std::string 中,
我用 C++ 编写了这段代码,使用运算符重载对 2 个矩阵进行加法和乘法运算。当我执行代码时,它会在第 57 行和第 59 行产生错误,非法结构操作(两行都出现相同的错误)。请解释我的错误。提前致谢:
我是 C++ 的初学者,我想编写一个简单的程序来交换字符串中的两个字符。 例如;我们输入这个字符串:“EXAMPLE”,我们给它交换这两个字符:“E”和“A”,输出应该类似于“AXEMPLA”。 我在
我需要以下代码的帮助: 声明 3 个 double 类型变量,每个代表三角形的三个边中的一个。 提示用户为第一面输入一个值,然后 将用户的输入设置为您创建的代表三角形第一条边的变量。 将最后 2 个步
我是新来的,如果问题不好请见谅 任务:将给定矩阵旋转180度 输入: 1 4 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 输出: 16 15 14 13 12 11
我是一名优秀的程序员,十分优秀!