- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个 Profile 模型,它与 Django 的 User 模型具有一对一的关系,我还有另一个模型,称为 Permission(与 Django 的内部权限概念无关),它有一个 Profile 的外键。像这样:(为了简单起见,我已经删除了这里的大部分字段)
from django.db import models
from django.contrib.auth.models import User as DjangoUser
class Account(models.Model):
name = models.CharField(max_length=200, db_index=True)
class Profile(models.Model):
django_user = models.OneToOneField(DjangoUser)
default_account = models.ForeignKey(Account)
class Permission(models.Model):
# Which user has the permission
user = models.ForeignKey(Profile, db_index=True)
# Which account they have the permission on
account = models.ForeignKey(Account, db_index=True)
我想为 Permission 创建一个序列化程序,它将创建这样的对象:
{
"user": "me@example.com",
"account": 123
}
其中“account”的值是帐户的主键(所以这很简单,我可以使用 PrimaryKeyRelatedField),“user”的值是用户的电子邮件地址(这是我还没有弄清楚的部分,因为电子邮件地址没有直接存储在 Profile 对象中,而是在关联的 DjangoUser 对象中)。另请注意,这不是只读的 - 在创建权限时,它确实需要能够从电子邮件地址反序列化为 Profile 对象。
到目前为止我已经尝试过一些东西,用于在 Permission 序列化器上代表用户......
1.
user = serializers.RelatedField(read_only=False)
对于这个,如果我以“用户”身份发布电子邮件地址(或主键或其他任何内容),它会返回 400 错误,提示 {"user": "This field is required."
,好像我根本没有包含该字段。
2.
user = serializers.SlugRelatedField(slug_field='django_user.email')
有了这个,我得到了 AttributeError: 'Profile' object has no attribute 'django_user.email'
。如果我使用 'django_user__email'
,也会发生同样的事情。
有什么想法吗?
最佳答案
根据 Django REST Framework 序列化程序引用 (http://www.django-rest-framework.org/api-guide/fields/#core-arguments):
The name of the attribute that will be used to populate the field. May be a method that only takes a self argument, such as URLField(source='get_absolute_url'), or may use dotted notation to traverse attributes, such as EmailField(source='user.email').
因此,如果 source='user.email'
不起作用,您可以尝试创建一个方法(例如 get_user_email
),在 source 中使用它
字段并让它手动返回用户电子邮件。
关于python - Django REST 框架 : SlugRelatedField for indirectly-related attribute?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26167406/
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a software
我意识到这个问题已经提出,但是由于与我在类似问题上看到的原因不同,导致了我的原因,所以这是我的设置。 我有2个C#项目A和B,项目B引用了一个第三方库Indirect。 A将调用在B中定义的静态方法,
我想要实现的是,如果 AB 列中的一个单元格等于"is"并且 AC 列中的一个单元格是空白的,那么一定范围的单元格将被格式化。目前,该规则没有格式化它应该格式化的单元格。我将此代码基于我正在使用的另一
我正在尝试动态计算电子表格的每周周数,因为每周都会在标题中的日期将新数据添加到列中。我的数据如下所示: Name WoW 9/27/2018 10/4/2018 10/11/2018
我已经四处寻找如何对整列(在另一张纸上)使用间接命令,但 react 有限 我见过它必须是这样的 =SUMIF(Site!$A:$A,D11,indirect("Site!$F",Row($F)) 我
我在下面有一个 INDIRECT 公式,问题是当我将“F3”单元格拖动到填充单元格时,它似乎不是相对的。 =INDIRECT("'Sheet 2'!F3") 如何使“F3”相对? 谢谢!! 最佳答案
我正在寻找一种方法,使间接公式忽略错误并打印 0。我让它以一种迂回的方式工作,但希望它更整洁。 我有一个INDIRECT公式来从单独的工作表加载单元格 =INDIRECT("'Invoice (2)'
我有几个单元格计算来自多个工作表的单个单元格的总数,在这种情况下,来自 Week 中的每个工作表的“Y3”,其中 n 是从 1 到 10 的整数: =SUMPRODUCT(COUNTIF(INDIRE
我正在尝试使用自定义创建的引用字符串从表中引用总计。这基本上可以正常工作,直到我在以不同语言安装的 excel 中打开电子表格。所以我所拥有的是: INDIRECT("Attendees[[#Tota
我在这个示例中有 4 张纸,每张纸都有一个 A1 中的值,如下所示: Sheet1 - A1=18 Sheet2 - A1=15 Sheet3 - A1=197 Sheet4 - A1=534 然后在
我不理解这个错误(C2100:非法间接)。我标记了三个实例——都在底部附近。我在网上看过,我知道这与我的指示有关,但在 8 小时后,我完全迷路了。这里可能还有其他一些错误,但我什至无法分辨,因为我无法
我想使用 Excel 中的间接函数引用另一个工作簿,假设其名称为“My workbook.xlsm”。 但是,“我的工作簿”文件名之前或之后可以有任何其他字符串/字符。 假设我正在尝试查找“查找值”
所以我有二维 boolean 数组 a,它应该代表不同人之间的关系/友谊。每个人都通过他们的 id(数组索引)来识别,如果例如a[1][0] 为 true,则 1 和 0 是 friend 。如果 2
据我了解,如果 H4 中的值为 5,则有两种方法可以引用该单元格: =H4 和 =INDIRECT("H4") 不过,我无法找到一种方法来使其与名称引用一起工作。例如,如果我想计算一些数据的总和,我可
我正在尝试动态分配一个连续的内存块,存储一些整数值并显示它。 #include #include void main() { int i; int *ptr; ptr=
我正在尝试解决命题逻辑中的一个问题,我认为我从未在任何地方看到过这个问题。我将它张贴在这里,看看是否有人有一个有希望的标准解决方案。 问题:给定一个命题可满足逻辑公式F和一个出现在F中的命题p,判断是
p是一个指向数组arr的指针,我们可以通过*p获取数组arr ,但是为什么用*p[2]获取不到第二个元素呢? 会报错: invalid indirect of p[1] (type int) 以下代码
看各种pages in the Android docs ,其中一些列出了“已知的间接子类”。这是什么意思? 最佳答案 对于接口(interface),它是实现该接口(interface)的类的列表。
我目前正在使用公式 =匹配(A2,间接(Q20):间接(Q22),0)其中 A2 包含要在一个范围内搜索的项目。范围是动态的,Q20 的起点为 =地址(Q17,3,4) Q22 持有 =地址(Q18,
我需要使用 Excel Indirect() 函数来引用非连续范围。这个( How to define a non continuous range in COUNTIF )答案给出了一个例子。 总之
我是一名优秀的程序员,十分优秀!