Java - 使用 Jena APi - 从 RDF 文件获取数据

标签 java rdf sparql jena owl

我的问题涉及具有数据类型属性hasFirstNamehasLastNamehasDateOfBirthhasGender的类Person。 我正在使用 Java 和 Jena API。

这是一个人在我的 RDF 文件中的表示方式。

<rdf:Description rdf:about="http://www.fam.com/FAM#Bruno04/02/1980 ">
    <j.0:FAMhasGender>H</j.0:FAMhasGender>
    <j.0:FAMhasDateOfBirth>04/02/1980</j.0:FAMhasDateOfBirth>
    <j.0:FAMhasLastName>DS </j.0:FAMhasLastName>
    <j.0:FAMhasFirstName> Bruno</j.0:FAMhasFirstName>
 </rdf:Description>

如果性别是女性,我想在下面写下这一行:

[label= \"" +firstName+ " \"\n\n\"D.Naiss:"+dnai1+"\", "+shape2+"]

因此,例如,如果有 3 名女性,则文件必须包含采用该格式的 3 行。形状值(然后是输出线)将取决于性别,这就是为什么我不能对两种性别使用同一行。如果是女性则为 Shape2,如果为男性则为 Shape。

对于每个性别为男性的人,我想在下面输出这一行:

[label= \"" +firstName+ " \"\n\n\"D.Naiss:"+dnai1+"\", "+**shape**+"]

我遇到的问题是他只输出了一名女性和一名男性以及相应的行。然而,我的 rdf 文件中有不止一名女性和一名男性。

这是相关代码。你能告诉我应该修改什么来解决这个问题吗? 非常感谢。

public void accessProp() {

    readFile(inputFile); // rdf
    String fname;
    String dd;
    String gen;

    ExtendedIterator instances = onto.person.listInstances();
    Individual instance = null;
    Individual firstInstance = null;
    while (instances.hasNext()) {
        instance = (Individual) instances.next();

        gen = instance.getPropertyValue(onto.hasGender).toString();
        fname = instance.getPropertyValue(onto.hasFirstName).toString();
        dd = instance.getPropertyValue(onto.hasDateOfBirth).toString();

        writeFile(fname, dd, genr);
    }
}

// Write text file
public void writeFile(String fn, String dbir, String gn) {
    String fileout = "D:/file1.txt";
    String firstName = fn;
    String dateB = dbir;
    String gender = gn;

    BufferedWriter out;
    try {
        out = new BufferedWriter(new FileWriter(fileout, true));

        if (gender.equals("F")) {
            out.write("[label= \"" + firstName + " \"\n\n\"D.Naiss:" + dnai1 + "\", " + shape + "]");
        } else if (gender.equals("M")) {
            out.write("[label= \"" + firstName + " \"\n\n\"D.Naiss:" + dnai1 + "\", " + shape2 + "]");
        }

        out.newLine();

        // flushes and closes the stream
        out.close();
    } catch (IOException e) {
        System.out.println("There was a problem:" + e);
    }
}

最佳答案

在不了解 Jena 的情况下,我没有在您的代码中看到任何仅选择男性条目的地方。 检查 while (instances.hasNext()) { 循环以查看它循环经过哪些实例。

因为您为每个实例写入一行,所以 writeLine() 方法同时写入男性和女性条目,因此可能是这样的

ExtendedIterator instances = onto.person.listInstances();

返回您在文件中看到的两个男性和女性条目。

此外,您的示例 RDF 条目的性别值为 H,但在代码中您使用 MF 来检查它。

关于Java - 使用 Jena APi - 从 RDF 文件获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13915865/

相关文章:

java - 使用 Lucene 索引 NTriples

java - Stardog 自定义聚合函数在耶拿不可用

validation - 如何克隆或复制 Jena-Ontology-Model (OntModel) 以应用临时更改?

java - IntelliJ 调试器不会在 Maven 项目的断点处暂停

java - 从 Notes DateTime 对象设置 Java 日期对象

java - 使用 Java EE 注释通过 JUnit 进行 REST 服务测试

sparql - DBPEDIA + SPARQL 根据类型选择电影

java - 多个 TestNG 组 : can they be ANDed exclusively from the command line?

java - 针对 Jena 数据集默认图的 SPARQL 查询

scala - 使用大量带有 self 类型的 mixin