在drools中声明对象excel决策表

时间:2013-03-16 15:16:54

标签: java drools

我正在尝试使用Drools决策表。 我面临的问题是drools没有为我分配当前对象的变量。

我从drools收到此错误:

  

Drools错误:无法解析规则编译错误患者

我的excel文件如下所示:

enter image description here

我的部分实验室代码如下:

DecisionTableConfiguration dtconf = KnowledgeBuilderFactory.newDecisionTableConfiguration();
        dtconf.setInputType(DecisionTableInputType.XLS);
        dtconf.setWorksheetName("Sheet1"); 

        KnowledgeBuilder kbuilder = KnowledgeBuilderFactory.newKnowledgeBuilder();
        Resource r = ResourceFactory.newClassPathResource("rules.xls");
        kbuilder.add(r, ResourceType.DTABLE, dtconf);

        SpreadsheetCompiler compiler = new SpreadsheetCompiler();
        String drl = compiler.compile(r.getInputStream(), InputType.XLS);

        System.out.println(drl);

        if(kbuilder.hasErrors()) {
            for(KnowledgeBuilderError err : kbuilder.getErrors()) {
                System.out.println("Drools error: " + err.getMessage());
            }
            model.addAttribute("droolErrors", kbuilder.getErrors());
            return "index";
        }

        KnowledgeBase knowledgeBase = KnowledgeBaseFactory.newKnowledgeBase();
        knowledgeBase.addKnowledgePackages(kbuilder.getKnowledgePackages()); 
        StatefulKnowledgeSession dsess = knowledgeBase.newStatefulKnowledgeSession();

        for(Patient p : patients) {
            dsess.insert(p);
        }

        model.addAttribute("factCount", dsess.getFactCount());

        KnowledgeRuntimeLogger logger = KnowledgeRuntimeLoggerFactory.newFileLogger(dsess, "test"); 

        int res = dsess.fireAllRules();
        System.out.println(res);
        dsess.dispose();


        logger.close();

生成的drl看起来像这样:

package com.sorkmos.drools.domain;
//generated from Decision Table
import com.sorkmos.drools.domain.*;
// rule values at C11, header at C6
rule "Risks rules_11"
    when
        Patient(age == 75)
    then
        patient.setAge(22);
end


Drools error: Rule Compilation error patient cannot be resolved

很明显,我需要设置“患者”变量。但我无法弄清楚如何。 正确的drl版本是这样的:

package com.sorkmos.drools.domain;
//generated from Decision Table
import com.sorkmos.drools.domain.*;
// rule values at C11, header at C6
rule "Risks rules_11"
    when
        Patient(age == 75);
        patient: Patient();
    then
        patient.setAge(22);
end

1 个答案:

答案 0 :(得分:0)

问题是从Cell C到G的Patient模式没有定义任何变量。如果您确定要拥有2个独立的患者模式,那么您必须在那里绑定变量。当然,如果绑定'patient',请确保列C到G和H是独占的。否则,您将最终得到重复的变量定义。 根据我所掌握的稀缺信息,我猜你不想拥有不同的患者模式。如果是这种情况,只需将单元格H8与[C-G] 8合并,并确保该值为患者:患者。

希望它有所帮助,