python - django-import-export ForeignKeyWidget 不进行查找

标签 python django excel django-import-export

我正在尝试使用 django-import-export 导入一个 xls 文件。

这是我的:

class CourseResource(resources.ModelResource):

   course_number = fields.Field(column_name='Kursnummer', attribute='course_number', widget=CharWidget())

   school_year = fields.Field(column_name='Schuljahr', attribute='school_year',
                          widget=ForeignKeyWidget(model=SchoolYear, field='name'))


   #other fields....

   class Meta:
       model = Course
       exclude = ('students')
       export_order = ('id', 'course_number', 'school_year')

SchoolYear 模型:

class SchoolYear(models.Model):
   name = models.CharField(max_length=25, unique=True)
   start_date = models.DateField(verbose_name="Beginn")
   end_date = models.DateField(verbose_name="Ende")

   def __str__(self):
       return self.name

   def __unicode__(self):
       return self.name

类(class)模型:

class Course(models.Model):

   course_number = models.CharField(max_length=25, verbose_name="Kursnummer")
   school_year = models.ForeignKey(SchoolYear, default=30, verbose_name="Schuljahr")

   #some other fields...

   students = models.ManyToManyField(Student, verbose_name="Schüler", null=True, blank=True, related_name="courses")

   class Meta:
       unique_together = ('course_number', 'school_year',)
       verbose_name = "Kurs"
       verbose_name_plural = "Kurse"
       managed = True

   def __str__(self):
       return "%s (%s)" % (self.course_number, self.school_year)

我的 excel 文件中的示例行如下所示(第二列是类(class)编号,第三列是学年名称,然后是更多字段):

... 7aMa 2015/2016 ...

当我尝试在 django 管理中导入文件时,我收到此错误消息:

Row number: 1 - Column 'school_year': invalid literal for int() with base 10: '2015/2016' [...]
Traceback (most recent call last):
File "/Users/amishelli/Dropbox/IMS/ims2/import_export/resources.py", line 441, in import_row
self.import_obj(instance, row, dry_run)
File "/Users/amishelli/Dropbox/IMS/ims2/import_export/resources.py",    line 300, in import_obj
self.import_field(field, obj, data)
File "/Users/amishelli/Dropbox/IMS/ims2/import_export/resources.py", line 290, in import_field
field.save(obj, data)
File "/Users/amishelli/Dropbox/IMS/ims2/import_export/fields.py", line 112, in save
setattr(obj, attrs[-1], self.clean(data))
File "/Users/amishelli/Dropbox/IMS/ims2/import_export/fields.py", line 68, in clean
 raise ValueError("Column '%s': %s" % (self.column_name, e))
 ValueError: Column 'school_year': invalid literal for int() with base 10: '2015/2016'

我认为 SchoolYear 的 ForeignKey 查找不起作用。我究竟做错了什么?

最佳答案

我现在找到了答案。我的 CourseAdmin 缺少资源类,所以我的 CourseResource 根本没有效果。我添加了这个:

class CourseAdmin(ImportExportActionModelAdmin, ImportExportModelAdmin):
    list_display = ('course_number', 'school_year', 'school_subject', 'teacher', 'lessons_per_week', 'major')
    list_filter = ('school_year', 'school_subject', 'teacher')
    resource_class = CourseResource

admin.site.register(Course, CourseAdmin)

工作起来很有魅力! :)

关于python - django-import-export ForeignKeyWidget 不进行查找,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37978208/

相关文章:

python - Apache mod_wsgi Django 设置 - 禁止您无权访问此服务器上的/mysite

python - 在 Python 的字典中创建特定值的总和

python - ValueError:输入包含 NaN、无穷大或对于 dtype ('float64' 来说太大的值),即使 isnan 和 isinf 为 false 且 dtype=float64 时也是如此

python - LSTM 的输出不会因不同的输入而改变

python - Django,更改用户模型的用户名字段

python - Django 中的 CBV mixin 是什么?

Excel 365 - 搜索表为每行返回 true

excel - 需要 excel 宏 - vba 的帮助

vba - 更改代码,使其不会填充更多单元格,只需替换为更改

python - 作业因阶段失败而中止 : Task 5 in stage 3. 0 失败 1 次