ValueError:无法在django中分配

时间:2011-11-29 08:20:41

标签: python xml django django-piston

我在尝试向模型添加/发布数据时遇到了问题。 这就是我在python manage.py shell中所做的:

>>> from booking.models import *
>>> qa = Product.objects.get(id=5)
>>> sd = Booking.objects.create(
... date_select = '2011-11-29',
... product_name = qa.name,
... quantity = 1,
... price = qa.price,
... totalcost = 20,
... first_name = 'lalala',
... last_name = 'sadsd',
... contact = '2321321',
... product = qa.id)
Traceback (most recent call last):
  File "<console>", line 10, in <module>
  File "/usr/local/lib/python2.7/dist-packages/django/db/models/manager.py", line 138, in create
    return self.get_query_set().create(**kwargs)
  File "/usr/local/lib/python2.7/dist-packages/django/db/models/query.py", line 358, in create
    obj = self.model(**kwargs)
  File "/usr/local/lib/python2.7/dist-packages/django/db/models/base.py", line 352, in __init__
    setattr(self, field.name, rel_obj)
  File "/usr/local/lib/python2.7/dist-packages/django/db/models/fields/related.py", line 331, in __set__
    self.field.name, self.field.rel.to._meta.object_name))
ValueError: Cannot assign "5": "Booking.product" must be a "Product" instance.

我不知道为什么会这样...... product = qa.id不等于Booking.product?

这是我的model.py

from django.db import models

# Create your models here.
class Product(models.Model):
    name = models.CharField(max_length=50, null=True, unique=False)
    quantity = models.IntegerField(max_length=10, null=True)
    price = models.FloatField()
    def __unicode__(self):
        return self.name

class Booking(models.Model):
    date_select = models.DateField(auto_now=False, auto_now_add=False)
    product_name = models.CharField(max_length=50, blank=True, null=True)
    quantity = models.IntegerField(max_length=10, blank=True, null=True)
    price = models.FloatField()
    totalcost = models.FloatField()
    first_name = models.CharField(max_length=50, null=True, blank=True, unique=False)
    last_name = models.CharField(max_length=50, null=True, blank=True, unique=False)
    contact = models.CharField(max_length=50, null=True, blank=True, unique=False)
    product = models.ForeignKey(Product)
    def __unicode__(self):
        return self.first_name

和我的handlers.py

from django.utils.xmlutils import SimplerXMLGenerator
from piston.handler import BaseHandler
from booking.models import *
from piston.utils import rc, require_mime, require_extended, validate
class BookingHandler(BaseHandler):
    allowed_method = ('GET', 'POST', 'PUT', 'DELETE')
    fields = ('id', 'date_select', 'product_name', 'quantity', 'price','totalcost', 'first_name', 'last_name', 'contact', 'product')
    model = Booking

    def read(self, request, id):
        if not self.has_model():
            return rc.NOT_IMPLEMENTED
        try:
            inst = self.model.objects.get(id=id)
            return inst
        except self.model.MultipleObjectsReturned:
            return rc.DUPLICATE_ENTRY
        except self.model.DoesNotExist:
            return rc.NOT_HERE

    def create(self, request, *args, **kwargs):
        if not self.has_model():
            return rc.NOT_IMPLEMENTED

        attrs = self.flatten_dict(request.POST)
        if attrs.has_key('data'):
            ext_posted_data = SimplerXMLGenerator(request.POST.get('data'))
            attrs = self.flatten_dict(ext_posted_data)
        try:
            inst = self.model.objects.get(**attrs)
            return rc.DUPLICATE_ENTRY
        except self.model.DoesNotExist:
            inst = self.model(**attrs)#error??
            inst.save()
            return inst
        except self.model.MultipleObjectsReturned:
            return rc.DUPLICATE_ENTR

有人能帮我解决一下情况吗?

提前感谢...

2 个答案:

答案 0 :(得分:7)

您将产品指定为

product = qa.id

你应该这样做

product = qa

答案 1 :(得分:6)

product = qa

使用ForeingKey你应该分配一个对象,而不是id。