- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 Django Import/Export,我在将外键字段导入到 Django 模型中时遇到问题。具体来说,我的模型中有三个字段需要导入(第四个字段是参与者,具有默认值,因此我们可以忽略该字段),其中一个是 IntegerField
,另外两个是 ForeignKey
字段。
在导入之前,所有三个字段都会转换为数字格式。但是, ForeignKey
字段无法读取这些值,而是导入 NaN
(大概是因为我已将这些模型字段设置为 null=True
。
我针对类似问题尝试了多种解决方案,但都没有解决这个问题。
我在这里做错了什么?
class User(auth.models.User,auth.models.PermissionsMixin):
def __str__(self):
return "@{}".format(self.username)
class Forskningsresultater(models.Model):
id = models.IntegerField(primary_key=True)
authors = models.ManyToManyField(settings.AUTH_USER_MODEL, through='PersonRes', blank=True,related_name='authors',verbose_name="Authors")
... (plus irrelevant fields for this question)
class PersonRes(models.Model):
id = models.IntegerField(primary_key=True)
user = models.ForeignKey(settings.AUTH_USER_MODEL,on_delete=models.CASCADE,null=True,verbose_name="user")
forskningsresultater = models.ForeignKey(Forskningsresultater,on_delete=models.CASCADE, null=True,verbose_name="forskningsresultater")
participant = models.BooleanField(default=True)
def __str__(self):
return "{}. Result {}: {}".format(self.id,self.forskningsresultater, self.user)
from import_export import widgets, fields, resources
class PersonResResource(resources.ModelResource):
user = fields.Field(column_name='user_id', attribute='user', widget=widgets.ForeignKeyWidget(settings.AUTH_USER_MODEL, 'id'))
forskningsresultater = fields.Field(column_name='forskningsresultater_id', attribute='forskningsresultater', widget=widgets.ForeignKeyWidget(Forskningsresultater, 'id'))
class Meta:
model = PersonRes
fields = ('id','user','forskningsresultater','participant',)
from import_export.admin import ImportExportModelAdmin
class PersonResAdmin(ImportExportModelAdmin):
class Meta:
resource_class: PersonResResource
admin.site.register(PersonRes,PersonResAdmin)
...
df_persres[['A']] = df_persres[['A']].apply(pd.to_numeric)
df_persres[['B']] = df_persres[['B']].apply(pd.to_numeric)
df_persres[['C']] = df_persres[['C']].apply(pd.to_numeric)
df_persres.columns =['id','user_id','forskningsresultater_id']
if( len(df_persres.index) != 0):
import tablib
from import_export import resources
from accounts.models import PersonRes
personres_resource = resources.modelresource_factory(model=PersonRes)()
antall = len(df_persres.index)
for row in range(antall):
dataset = tablib.Dataset([ df_persres.iat[row,0],
df_persres.iat[row,1],
df_persres.iat[row,2]],
headers=['id', 'user_id', 'forskningsresultater_id'])
result = personres_resource.import_data(dataset, dry_run=True)
else:
pass
打印 dataset
时,我得到以下信息(仅显示 dataset
的一个实例):
id |user_id|forskningsresultater_id
---------|-------|-----------------------
148097456|1480974|56
但是,当我使用 pd.DataFrame.from_records(PersonRes.objects.all().values())
打印模型时,我得到:
forskningsresultater_id id participant user_id
0 NaN 338884 True NaN
1 NaN 566233 True NaN
2 NaN 636223 True NaN
3 NaN 754756 True NaN
4 NaN 802856 True NaN
5 NaN 1005256 True NaN
...
最佳答案
列名称应如下所示(删除 _id):
user = fields.Field(column_name='user', attribute='user', widget=widgets.ForeignKeyWidget(settings.AUTH_USER_MODEL, 'id'))
forskningsresultater = fields.Field(column_name='forskningsresultater', attribute='forskningsresultater', widget=widgets.ForeignKeyWidget(Forskningsresultater, 'id'))
关于python - Django导入/导出: ForeignKey fields return None,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45190768/
询问 unrelated question我有这样的代码: public boolean equals(Object obj) { if (this == obj) retur
在我之前的一个问题中 js: Multiple return in Ternary Operator我询问了有关使用三元运算符返回多个参数的问题。但是现在参数IsActveUser boolean(t
假设我有一个带有 return 的 if 语句。从效率的角度来看,我应该使用 if(A > B): return A+1 return A-1 或 if(A > B): return
例如考虑以下代码: int main(int argc,char *argv[]) { int *p,*q; p = (int *)malloc(sizeof(int)*10); q
PyCharm 对这段代码发出警告,说最后一个返回是不可访问的: def foo(): with open(...): return 1 return 0 如果 ope
我想实现这样的目标: 如果在返回 Json 的方法中抛出异常,则返回 new Json(new { success = false, error = "unknown"}); 但如果方法返回 View
它是多余的,但我正在学习 JS,我想知道它是如何工作的。 直接从模块返回函数 let func1 = function () { let test = function () {
我不明白我应该使用什么。我有两页 - intro.jsp(1) 和 booksList.jsp(2)。我为每一页创建了一个 Controller 类。第一页有打开第二页的按钮:
我最近在 Joomla 组件(Kunena,更准确地说是 Kunena)中看到这段代码,那么使用 $this->return VS 简单的 return 语句有什么区别. 我已经用谷歌搜索了代码,但没
我的类实现了 IEnumerable。并且可以编译这两种方式来编写 GetEnumerator 方法: public IEnumerator GetEnumerator() { yield r
我只是在编码,我想到了一个简单的想法(显然是问题),如果我有一个像这样的函数: int fun1(int p){ return(p); } 我有一个这样的函数: int fun1(int p){
这个问题在这里已经有了答案: What does the comma operator do in JavaScript? (5 个答案) 关闭 9 年前。 function makeArray
假设我写了一个 for 循环,它将输出所有数字 1 到 x: x=4 for number in xrange(1,x+1): print number, #Output: 1 2 3 4 现
我最近在这个 Apache Axis tutorial example. 中看到了下面的一段代码 int main() { int status = AXIS2_SUCCESS; ax
function a(){ return{ bb:"a" } } and function a(){ return { bb:"a" } } 这两个代码有什么区别吗,如果有请
function a() { return 1; } function b() { return(1); } 我在 Chrome 的控制台中测试了上面的代码,都返回了 1。 function c()
考虑这三个函数: def my_func1(): print "Hello World" return None def my_func2(): print "Hello World"
这可能是一个愚蠢的问题,但我正在努力,如果有一种简明的方法来测试函数的返回结果,如果它不满足条件,则返回该值(即,传递它)。。现在来回答一个可能的问题,是的,我正在寻找的类似于例外提供的东西。然而,作
我正在测试一个函数,并尝试使用 return 来做什么,并在 PowerShell 5.1 和 PwSh 7.1 中偶然发现了一个奇怪的问题,即 return cmdlet似乎不适合在团体中工作: P
这个问题已经有答案了: Return in generator together with yield (2 个回答) Why can't I use yield with return? (5 个回
我是一名优秀的程序员,十分优秀!