私は独自のオントロジーを開発し (クラス、プロパティなどを定義しました)、オントロジーを sparql で調査したいと考えています。
protégé 2000 (オープンソースのオントロジー エディタ) ではすべて正常に動作しますが、要求した sparql を Python で実装しようとすると、いくつかの問題が発生しました。
私はJavaでそれを行いましたが、うまくいきましたが、それは私が望んでいるものではありませpyjnius
ん.
sparql を使用してオントロジーを調査するにはどうすればよいですか? Pythonでジェナを使用する方法はありますか?
それが私がJavaでそれをした方法です:
try{
Model model = ModelFactory.createDefaultModel();
String FName = "C:\\Users\\p\\Desktop\\protégé project jour\\jour.owl";
InputStream inStr = FileManager.get().open(FName);
if (inStr == null) { throw new IllegalArgumentException("Fichier non trouvé");}
// Lire le fichier RDF vers le modèle précédemment créé.
model.read(inStr, "");
//****************************
String requete =
//***=====This is the query that works good in the ontology with properties between classes
"PREFIX OntoJO:<http://www.owl-ontologies.com/Ontology1400008538.owl#>" +
"SELECT ?path " +
"WHERE { "
+ " ?n OntoJO:signee_par '"+choixsignrech1.getText()+"' ."
+ " ?s OntoJO:mot_cle '"+choixclrech1.getText()+"' ."
+ " ?m OntoJO:secteur '"+choixsecrech1.getSelectedItem()+"' ."
+ " ?f OntoJO:ministere '"+choixminisrech1.getSelectedItem()+"' ."
+ " ?r OntoJO:synonymes '"+choixsyrech1.getText()+"' ."
+ "?n OntoJO:a_un_chemin ?y . "
+ "?s OntoJO:a_un_chemin ?y . "
+ "?m OntoJO:a_un_chemin ?y . "
+ "?f OntoJO:a_un_chemin ?y . "
+ "?r OntoJO:a_un_chemin ?y . "
+ "?y OntoJO:chemin ?path . }";
Query query = QueryFactory.create(requete);
QueryExecution qexec = QueryExecutionFactory.create(query, model);
try {
ResultSet results = qexec.execSelect();
while (results.hasNext()){
QuerySolution soln = results.nextSolution();
RDFNode name = soln.get("path");
System.out.println(name);
javax.swing.JOptionPane.showMessageDialog(this,soln.get("path"));
}
} finally
{
qexec.close();
}
プロパティは次のとおりです: signee_par、mot_cle、secteur、ministere など ..... (フランス語で)、sqarql リクエストはこれらのプロパティに基づいています。
私はPythonでそれをしたいのですが、誰も私ができる方法を知っていますか?!