0

Java と Jena API を使用しています。"hasHusband""Haswife " 、" dateOfMarriage"という 3 つのオブジェクト プロパティを持つクラスMarriageがあります。最初の 2 つは、データ型プロパティ hasFirstNamehasLastNamedateOfBirth ...を持つクラス Personに関連付けられています。

以下のコードを使用して、夫の hasFirstName プロパティにアクセスできます。

StmtIterator iter = onto.model.listStatements(null,onto.hasHusband,(RDFNode)null);  
while (iter.hasNext()) {
    Statement stmt = iter.nextStatement();  
    Resource P = ((Resource) stmt.getObject());

    StmtIterator iter2 = onto.model.listStatements(((Resource) P),onto.hasFirstName,(RDFNode)null);  
    while (iter2.hasNext()) {
         Statement stmt2 = iter2.nextStatement();  
         firstnameHusband = stmt2.getObject().toString();
    }}

この行を変更したい

 StmtIterator iter2 = onto.model.listStatements(((Resource) P),onto.hasFirstName,(RDFNode)null);  

hasLastName と hasDateofBirth にもアクセスするには...

どうすればこれができるのか説明してもらえますか?

ありがとう

EDITED:@Pierre 今ではクラスPersonのみに関係しています。女性の場合、新しいファイル (テキスト ファイル) に出力したいのは、女性ごとに次の行です。

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

そして、それぞれの人のためにこれ:

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

違いは形状の値にあります。私が抱えている問題は、彼が 1 人の女性と 1 人の男性しか出力しないことです。

私の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>

関連するコードは次のとおりです。

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);
    }
}

私の問題を解決するために何をすべきか教えてもらえますか?

ありがとう

4

2 に答える 2

2

質問の意図を理解している場合は、各リソースの名、姓、生年月日などを提供するイテレーターが必要です。イテレータは、リソースごとに1行になります。

これがSPARQLがあなたのためにできることです。

概要:

PREFIX  : ...
SELECT *
{   ?z :hasHusband      ?p .
    ?p :hasFirstName    ?firstName ;
       :hasLastName     ?lastName ;
       :hasDateOfBirth  ?dob ;
    .
 }

on.modelにクエリを実行します。

于 2012-09-01T16:29:27.500 に答える
-1

特定のプロパティを取得するヘルパー関数を作成します。

public RDFNode getProperty(Resource subject,Property prop)
   {
   RDFNode object=null;
   StmtIterator iter2 = this.onto.model.listStatements(subject,prop,(RDFNode)null);  
    while (iter2.hasNext()) {
         object = iter2.nextStatement().getObject();
         break;
    }}
   iter2.close();
   return object;
   }

public String getPropertyAsString(Resource subject,Property prop)
   {
   RDFNode object=getProperty(subject,prop);
   return object==null?null:object.toString();
   }

(...)
String s1=getPropertyAsString(P,onto.hasFirstName);
String s2=getPropertyAsString(P,onto.hasLastName);
(...)
于 2012-09-01T11:07:17.143 に答える