2016-12-23 1 views
0

Heat 인스턴스를 여러 개 저장하고 목록에 저장하려고 시도했습니다. heats 다음 데이터로 bulk_create의 목록을 사용했습니다. 내 views.pyDjango - TypeError : int() 인수는 'dict'이 아닌 문자열 또는 숫자 여야합니다.

@transaction.atomic 
def create(self, request): 
    heats = [] 
    for item in request.data: 
     animal = Animal(item['animal']) 
     heat = Heat(item['heat']) 
     heat.animal = animal 

     heats.append(heat) 

    Heat.objects.bulk_create(heats) 

request.data에서 내 models.py

class Animal(models.Model): 

    farm = models.ForeignKey(Farm, related_name='farm_animals', on_delete=models.CASCADE) 
    herd = models.ForeignKey(Herd, related_name='animals', on_delete=models.CASCADE) 

    name = models.CharField(max_length=25) 
    .... 

class Heat(models.Model): 

    # Relationship Fields 
    animal = models.ForeignKey(Animal, related_name='heats', on_delete=models.CASCADE) 

    # Fields 
    .... 

에서

직렬화 JSON이다. 여기가 어떻게 생겼는지.

[ 
    { 
     "animal" : { 
      "id" : 1, 
      .... 
     }, 
     "heat" : { 
      .... 
     } 
    }, 
    { 
     "animal" : { 
      "id" : 2, 
      .... 
     }, 
     "heat" : { 
      .... 
     } 
    }, 
    { 
     "animal" : { 
      "id" : 3, 
      .... 
     }, 
     "heat" : { 
      .... 
     } 
    } 
] 

하지만 난이 오류가있어 : 내가 개발 장고에 새로운 오전 이후 완전히 상황을 이해할 수 없다

Traceback (most recent call last): 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\core\handlers\exception.py", line 39, in inner 
    response = get_response(request) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\core\handlers\base.py", line 187, in _get_response 
    response = self.process_exception_by_middleware(e, request) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\core\handlers\base.py", line 185, in _get_response 
    response = wrapped_callback(request, *callback_args, **callback_kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\views\decorators\csrf.py", line 58, in wrapped_view 
    return view_func(*args, **kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\rest_framework\viewsets.py", line 83, in view 
    return self.dispatch(request, *args, **kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\rest_framework\views.py", line 477, in dispatch 
    response = self.handle_exception(exc) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\rest_framework\views.py", line 437, in handle_exception 
    self.raise_uncaught_exception(exc) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\rest_framework\views.py", line 474, in dispatch 
    response = handler(request, *args, **kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\utils\decorators.py", line 185, in inner 
    return func(*args, **kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\farm_management\heat\views.py", line 188, in create 
    Heat.objects.bulk_create(heats) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\manager.py", line 85, in manager_method 
    return getattr(self.get_queryset(), name)(*args, **kwargs) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\query.py", line 449, in bulk_create 
    self._batched_insert(objs_with_pk, fields, batch_size) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\query.py", line 1068, in _batched_insert 
    self._insert(item, fields=fields, using=self.db) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\query.py", line 1045, in _insert 
    return query.get_compiler(using=using).execute_sql(return_id) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\sql\compiler.py", line 1053, in execute_sql 
    for sql, params in self.as_sql(): 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\sql\compiler.py", line 1006, in as_sql 
    for obj in self.query.objs 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\sql\compiler.py", line 945, in prepare_value 
    value = field.get_db_prep_save(value, connection=self.connection) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\fields\__init__.py", line 755, in get_db_prep_save 
    prepared=False) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\fields\__init__.py", line 938, in get_db_prep_value 
    value = self.get_prep_value(value) 
    File "C:\Users\Web\Desktop\PyDev\Envs\djangular\lib\site-packages\django\db\models\fields\__init__.py", line 946, in get_prep_value 
    return int(value) 
TypeError: int() argument must be a string or a number, not 'dict' 

: 여기 TypeError: int() argument must be a string or a number, not 'dict'


전체 역 추적입니다. 도와주세요.

+0

당신이 request.data'이 어떻게 보이는지'의 예를 제공 할 수 있을까요? –

+0

확실히, 잠시만 기다려주십시오 –

+0

귀하의 질문에 답하기 위해서는 : 1) 모델 '동물'과 '열'의 필드 (유형 포함); 2)'request.data'의 구조. 그리고 순진하게도'Animal' 객체를 생성하지 않고 어떻게'Heat' 객체를 생성하는지 이해할 수 없습니다.'Heat' 객체는'Animal' 객체에 외래 키를 가져야합니다. – Fomalhaut

답변

1

새 동물 동물을 만들지 않고 기존 동물을 데이터베이스에서 추출해야합니다. 그리고 성능을 높이기 위해 동물을 "대량"으로 추출하는 것도 좋은 생각입니다.

코드 :

@transaction.atomic 
def create(self, request): 
    # Extracting animals 
    animal_id_list = [item['animal']['id'] for item in request.data] 
    animals = Animal.objects.in_bulk(animal_id_list) 
    animals_dict = {animal.id: animal for animal in animals} 

    # Creating heats 
    heats = [] 
    for item in request.data: 
     heat = Heat(**item['heat']) 
     heat.animal = animals_dict[item['animal']['id']] 
     heats.append(heat) 
    Heat.objects.bulk_create(heats) 
+0

응답 해 주셔서 감사합니다. 그러나 동물은 이미 데이터베이스에 존재합니다. 메신저는 열 기록을 만들고 싶었습니다. –

+0

DB에서 올바른 동물을 추출해야합니다. 나는 잠시 동안 나의 코드를 편집 할 것이다. – Fomalhaut

+0

고마워, 고마워. –

0

이것은 모델 간의 외래 키 관계 때문입니다. 모델에 animal이라는 ForeignKey가있는 경우 data_dictanimal_id 필드 여야합니다. 그러나 django.forms.model_to_dict()은 동물 필드가있는 dict을 반환합니다.
그래서 당신은 당신이 작동해야이 같은 animal_id

뭔가에 동물 필드의 이름을 변경해야 MyModel(**model_to_dict(my_instance));을 수행 할 수 없습니다
heat.animal_id = animal.id

+0

답장을 보내 주셔서 감사합니다. –

+0

여전히 작동하지 않겠지 만'print animal.id'를 실행하면 id가 아닌 값으로 전체 객체를 인쇄합니다. –

+0

동물 개체를 만든 후 id에 액세스하기 전에 저장하십시오. –

0

당신의 create 방법, 당신은 kwargs으로 item['heat']을 통과해야하며, 이전에 동물을 저장 열에서 그것을 사용합니다. 예 :

@transaction.atomic 
def create(self, request): 
    heats = [] 
    for item in request.data: 
     animal = Animal.objects.get(id=item['animal']['id']) 
     heat = Heat(animal=animal, **item['heat']) 

     heats.append(heat) 

    Heat.objects.bulk_create(heats) 
+0

'animal.save'를 사용하는 것은 좋지 않습니다. 그것은 잘 작동하지만 너무 느립니다. OP는'.save'를 피하기 위해'bulk_create'를 사용하려고합니다 – Fomalhaut

+0

OP에 동물들이 이미 데이터베이스에 저장되어있는 것을 몰랐습니다. –

+0

이것도 doin'anima.save()'없이도 작동하지만 동물 컨텍스트에서 불필요한 데이터를 제거해야합니다. –

관련 문제