“基于医疗知识图谱的问答系统”代码解析(三)

“基于医疗知识图谱的问答系统”代码解析(三)

question_parser.py —问题分析代码解析

“基于医疗知识图谱的问答系统”代码解析(一)
“基于医疗知识图谱的问答系统”代码解析(二)
“基于医疗知识图谱的问答系统”代码解析(四)
“基于医疗知识图谱的问答系统”代码解析(五)

#!/usr/bin/env python3
# coding: utf-8
# File: question_parser.py
# Author: lhy<lhy_in_blcu@126.com,https://huangyong.github.io>
# Date: 18-10-4

class QuestionPaser:

    '''构建实体节点'''
    # args 实质就是将函数传入的参数,存储在元组类型的变量args当中
    def build_entitydict(self, args):
        entity_dict = {
   }
        # 键值和类型
        for arg, types in args.items():
            # 遍历类型
            for type in types:
                # 若类型不在实体字典中,则添加
                if type not in entity_dict:
                    entity_dict[type] = [arg]
                else:
                    entity_dict[type].append(arg)
        return entity_dict

    '''解析主函数'''
    def parser_main(self, res_classify):
        args = res_classify['args']
        entity_dict = self.build_entitydict(args)       # 建立实体
        question_types = res_classify['question_types'] # 建立问题类别
        sqls = []                                       # 初始化
        for question_type in question_types:
            sql_ = {
   }
            sql_['question_type'] = question_type       # 将问题类别给sql_
            sql = []
            # 查找问题类型,将问题类型里的信息给sql 需要通过cypher语句查询,自己整理返回
            if question_type == 'disease_symptom':
                sql = self.sql_transfer(question_type, entity_dict.get('disease'))

            elif question_type == 'symptom_disease':
                sql = self.sql_transfer(question_type, entity_dict.get('symptom'))

            elif question_type == 'disease_cause':
                sql = self.sql_transfer(question_type, entity_dict.get('disease')
  • 4
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值