0

我知道以前有人问过这个问题,但没有一个问题有帮助,因此再次问..

我正在使用石墨烯并在将其传递给石墨烯之前解析一些 Elasticsearch 数据

PFB :- 我解决的功能

def resolve_freelancers(self, info):
    session = get_session()
    [ids, scores] = self._get_freelancers()
    freelancers = session.query(FreelancerModel).filter(FreelancerModel.id.in_(ids)).all()

    for index in range(len(ids)):
        print("index", scores[index])
        freelancers[index].score = scores[index]

    if self.sort:
        reverse = self.sort.startswith("-")
        self.sort = self.sort.replace("-", "")
        if self.sort == "alphabetical":
            freelancers = sorted(freelancers, key=lambda f: f.name if f.name else "", reverse=reverse)
        if self.sort == "created":
            freelancers = sorted(freelancers, key=lambda f: f.created_on, reverse=reverse)
        if self.sort == "modified":
            freelancers = sorted(freelancers, key=lambda f: f.modified_at, reverse=reverse)
    freelancers = [Freelancer(f) for f in freelancers[self.start:self.end]]
    session.close()
    return freelancers

现在如果我这样做

print(freelancers[index].score)

它给了我10.989184,它的类型是<class 'float'>

在我的class Freelancer(graphene.ObjectType):

我已经添加了score = graphene.Float()

现在,当我尝试添加score到我的查询时,它给出了错误..否则没有问题..我感兴趣的是在 json 响应中获取该分值..我不明白是什么导致了这个错误,我是对 Python 来说相当新,所以任何建议都将不胜感激。

请随时询问其他代码或信息,因为我试图粘贴我认为相关的任何内容

4

2 回答 2

0

实际上我不能将字段直接传递给石墨烯对象,我们需要在具有石墨烯对象的类的init方法中传递它,然后我们需要在解析器方法中返回(在我的例子中是 resolve_score)

于 2020-01-07T14:05:44.000 回答
0

所以我不能发表评论,或者我会,我很可能是错的,但这里有。

我的猜测是您正在调用的某个地方float(score),但该graphene.Float()类型无法通过float(). 这可能是由于继承自( graphene GH/Scalars )的graphene.Float类型具有如此多的数据,它可以在其数据结构中保存。graphene.Scalar

我的猜测是追捕float()电话并将其删除。如果这不起作用,我会转到Float.num您查询中的字段。

同样,这里的所有猜想,但我希望它有所帮助。

于 2020-01-06T18:42:05.123 回答