Как я могу импортировать экспорт с отношением по внешнему ключу

У меня есть файл csv с адресами пользователей и их номерами телефонов, как я могу импортировать его в мою таблицу адресов. Поскольку я не знаю идентификатор пользователя каждого пользователя.

У меня возникает следующая ошибка

Line number: 1 - null value in column "user_id_id" of relation "proj_auth_useraddress" violates not-null constraint DETAIL: Failing row contains (432, null, null, someaddress, , , null).

Но я знаю связь пользователя и адреса через его номер телефона. user_id__phone

# Models.py
class AppUser(AbstractUser):
    phone = models.CharField(max_length=15, unique=True, null=True)
    ...
class UserAddress(models.Model):
    address_id = models.AutoField(primary_key=True)
    user_id = models.ForeignKey(AppUser, on_delete=models.CASCADE)
    lat = models.FloatField(null=True, blank=True)
    lng = models.FloatField(null=True, blank=True)
    address1 = models.CharField(max_length=100)
    address2 = models.CharField(max_length=100, null=True, blank=True)
    city = models.CharField(max_length=50)
    pincode = models.IntegerField()

# Admin.py
@admin.register(UserAddress)
class AddressAdmin(ImportExportModelAdmin):
    resource_class = AddressAdminResource

# Resource.py
class AddressAdminResource(resources.ModelResource):
    class Meta:
        model = UserAddress
        import_id_fields = ('address_id',)

Если phone в AppUser уникален для каждого пользователя, то вы можете использовать pandas для миграции записей из csv в базу данных

Вы можете попробовать следующие решения:

import pandas as pd

csv_file = pd.read_csv(<yourcsvfile>.csv)

for index, rows in csv_file.iterrows():
    user_id__phone = rows["user_id__phone"]
    address1 = rows["address1"]
    address2 = rows["address2"]
    country = rows["country"]
    pincode = rows["pincode"]
    
    appuser_instance = AppUser.objects.get(phone=user_id__phone)
    
    # get_or_create is used to eliminate forming or any duplicate record 
    usershipping, created = UserAddress.objects.get_or_create(
        user_id=appuser_instance,
        address1=address1,
        address2=address2,
        city=city,
        pincode=pincode
        )
    
    # created defines whether new record was created or was edited on existing record
    # created = True (new record created)
    # craeted = False (edited on existing record)
    
    if created:
        usershipping.save()
Вернуться на верх