Java - Jena API - Получение более одного типа данных
Я использую Java и Jena API. У меня есть класс Marriage, которые имеют 3 свойства объекта, называемые "hasHusband", "Haswife" и "dateOfMarriage". Первые два связаны с классом Person, который имеет свойства типа hasFirstName, hasLastName, dateOfBirth....
Через код ниже я могу получить доступ к свойству 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+"]
Разница заключается в значении формы. У меня проблема в том, что он выводит только одну женщину и одного мужчину.
Человек представлен так в моем файле 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);
}
}
Можете ли вы сказать мне, что я должен сделать, чтобы решить мою проблему?
Спасибо
2 ответа
Создайте вспомогательную функцию для получения определенного свойства:
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);
(...)
Если я понимаю смысл вопроса, вам нужен итератор, который дает вам имя, фамилию, дату рождения и т. Д. Для каждого ресурса. Итератор будет одной строкой для каждого ресурса.
Это то, что SPARQL может сделать для вас.
В общих чертах:
PREFIX : ...
SELECT *
{ ?z :hasHusband ?p .
?p :hasFirstName ?firstName ;
:hasLastName ?lastName ;
:hasDateOfBirth ?dob ;
.
}
и запрос на.model.