0
def get_nlg(graph_query):
    driver = Graph("neo4j://localhost:7687", auth=("neo4j","password"))
    graph_response = graph.evaluate(graph_query)

对于上面的代码,我用下面的驱动代码替换了,但是它不起作用,neo4j驱动中的函数相当于py2neo中的evaluate()函数是什么?

    def get_nlg(graph_query):
        driver = GraphDatabase.driver("neo4j://localhost:7687", auth=("neo4j","password"))

        with driver.session() as session:
            graph_response = session.run(graph_query)
            return graph_response

当第二个代码的graph_response的结果传递给下面的代码时,我收到一个错误

TypeError: <neo4j.work.result.Result object at 0x7f94cf7f31d0> is not JSON serializable

class GetBiggestComponent(Action):
    def name(self):
        return "action_get_biggest_component"

    def run(self, dispatcher, tracker, domain):
        query = None
        intent = tracker.latest_message['intent']
        child_comp = tracker.get_slot('component_type_child')
        parent_comp = tracker.get_slot('component_type_parent')
        error = None
        graph_response = GenerateQuery.get_biggest_component(child_comp, parent_comp)
        graph_response['intent_name'] = intent['name']
        dispatcher.utter_custom_message(graph_response)
        return []

当它在行中传递时错误来了

dispatcher.utter_custom_message(graph_response)
4

1 回答 1

0

没有直接的等价物。您将需要进行run查询,然后从返回的第一条记录中选择第一个值。这就是evaluate幕后所做的一切。

于 2020-11-13T09:58:58.823 回答