问题描述
我正在尝试获取与每个用户关联的站点名称的平面列表。结果将写入 CSV 文件:
email,sites
a@b.com,site1|site2|site3
b@b.com,site3
StringAgg 用于在注释中展平 sites
。 has_flag
和 is_admin
都在注释中工作。所有这些字段都适用于 created_date
。但是,如果我尝试在 sites
或 has_flag
中包含 is_admin
,则会引发错误 'WhenNode' object has no attribute 'copy'
。
简化代码:
users = (
account.get_users()
.annotate(
is_admin=ExpressionWrapper(Q(role=1),output_field=BooleanField()),has_flag=ExpressionWrapper(Q(thing__isnull=False),output_field=BooleanField(),created_date=Func(F("created_at"),Value("YYYY-MM-DD"),function="to_char",output_field=CharField()),sites=StringAgg('usersite__site__name',delimiter="|"),)
.values_list(
"email","is_admin","has_thing","created_date","sites",)
)
class UserSite():
class Meta(object):
unique_together = ("user","site")
user = models.ForeignKey(User,on_delete=models.CASCADE)
site = models.ForeignKey(Site,on_delete=models.CASCADE)
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)