Django mod_wsgi PicklingError при сохранении объекта - PullRequest
1 голос
/ 20 июля 2010

Знаете ли вы какое-либо решение для этого:

[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162] mod_wsgi (pid=3072): Exception occurred processing WSGI script '/home/www/shop/django.wsgi'., referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162] Traceback (most recent call last):, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]   File "/usr/lib/python2.5/site-packages/django/core/handlers/wsgi.py", line 245, in __call__, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]     response = middleware_method(request, response), referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]   File "/usr/lib/python2.5/site-packages/django/contrib/sessions/middleware.py", line 36, in process_response, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]     request.session.save(), referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]   File "/usr/lib/python2.5/site-packages/django/contrib/sessions/backends/db.py", line 57, in save, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]     session_data = self.encode(self._get_session(no_load=must_create)),, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]   File "/usr/lib/python2.5/site-packages/django/contrib/sessions/backends/base.py", line 88, in encode, referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162]     pickled = pickle.dumps(session_dict, pickle.HIGHEST_PROTOCOL), referer: http://shop.domain.com/accounts/checkout/?
[Thu Jul 08 19:15:38 2010] [error] [client 79.162.31.162] PicklingError: Can't pickle <class 'decimal.Decimal'>: it's not the same object as decimal.Decimal, referer: http://shop.domain.com/accounts/checkout/?

Это происходит иногда при сохранении экземпляра модели с DecimalField: /.

views.py:

def checkout_authenticated(request):
    order = get_order(request)
    user = request.user

    if request.method == 'POST':
        form = OrderCheckoutForm(request.POST, instance = order)
        if form.is_valid():
            form.save()
...

forms.py:

class OrderCheckoutForm(forms.ModelForm):
    class Meta:
        model = Order
        exclude = ('status',
                   'user')

models.py:

class Shipping(models.Model):
    name = models.CharField(max_length = 256)
    price = models.DecimalField(max_digits = 10, decimal_places = 2)
    description = models.TextField(blank = True, null = True)
    cash_on_delivery = models.BooleanField(default = False)

class Order(models.Model):
    date = models.DateField(editable = False, auto_now_add=True)
    status = models.CharField(max_length = 1, choices = STATUS, default = Status.NEW)

    shipping = models.ForeignKey(Shipping, related_name = 'orders', null = True)
    address = models.ForeignKey(Address, related_name = 'address_order', null = True)
    invoice = models.BooleanField(default = False)
    company = models.ForeignKey(Company, related_name = 'company_order', blank = True, null = True)

Я думаю, что причина:

price = models.DecimalField(max_digits = 10, decimal_places = 2)

Заранее спасибо, Etam.

1 Ответ

2 голосов
/ 20 июля 2010

См. этот ответ . Это помогает?

РЕДАКТИРОВАТЬ (отвечая на ваш комментарий):

Боюсь, я недостаточно хорошо знаю django или ваш код, чтобы исправить ситуацию. У меня действительно есть более ясное представление об основной ошибке, хотя: до того, как эта ошибка произошла, был создан экземпляр decimal.Decimal, а затем по какой-то причине класс decimal.Decimal был переопределен. Класс pickle не работает, если он не может найти по имени определение класса для данного объекта.

Вот сеанс интерпретатора, показывающий похожую проблему:

>>> import cPickle
>>> class Foo(object):
...     pass
... 
>>> f = Foo()
>>> s = cPickle.dumps(f)
>>>
>>> # Redefine class Foo 
>>> class Foo(object):
...     pass
... 
>>> # Now attempt to pickle the same object that was created with the old Foo class
>>> s = cPickle.dumps(f)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
cPickle.PicklingError: Can't pickle <class '__main__.Foo'>: it's not the same object as __main__.Foo
>>>
>>> # Create an object with the new Foo class, and try to pickle it (this works)
>>> f2 = Foo()
>>> s = cPickle.dumps(f2)
...