我有一个rdf文件,其格式为:
<rdf:RDF
xmlns:geo="xyz"
xmlns:quality="xyz"
xmlns:purl="xyz"
xmlns:swrlb="xyz">
<rdf:Description rdf:about="title1">
<rdf:type rdf:resource="resource22"/>
<info:contains>fromdisk1</info:contains>
<info:has_text_value>
The location
</info:has_text_value>
</rdf:Description>
<rdf:Description rdf:about="title2">
<rdf:type rdf:resource="resource12"/>
<info:contains>fromdisk2</info:contains>
<info:has_text_value>
xyz
</info:has_text_value>
</rdf:Description>
</rdf:RDF>
我想存储info:has_text_value的值和相应的info:contains。我用JENA API尝试了很多方法,但都没有成功。你能指导我怎么做吗。任何源代码都会有很大的帮助。感谢
如果这是RDF的一个有代表性的示例,那么它有几个问题:
-
您不应该断言所有前缀都是
xyz
。当您使用缩写名称(如info:contains
或geo:something
)时,用于标识资源的实际URI是命名空间URI和本地名称的串联。如果使用得当,命名空间URI可以消除名称相似的概念的歧义,例如computers:monitor
和reptiles:monitor
可能分别表示显示屏和蜥蜴。但是,如果computers
和reptiles
名称空间都具有相同的值,那么两个URI都表示相同的资源,并且对一个资源所做的每一个语句也对另一个资源进行。不是个好主意。 -
您的示例不完整,因为未定义
info
命名空间,所以info:contains
不表示合法的属性URI。 -
资源
title2
具有相对URI,即它所表示的是相对于文档的基本URI的。这意味着,例如,如果您从不同的位置(例如磁盘上或http:
URL)读取包含文档的文件,则title2
的标识将发生更改。您可以通过添加xml:base
语句来断言文档的基本URI来减轻这种影响。
修复这些问题(并对名称空间进行猜测),得到:
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:geo="http://example.org/schema/geo#"
xmlns:quality="http://example.org/schema/quality#"
xmlns:purl="http://example.org/schema/purl#"
xmlns:swrlb="http://example.org/schema/swrlb#"
xmlns:info="http://example.org/schema/info#"
xml:base="http://example.org/data/test#"
>
<rdf:Description rdf:about="title1">
<rdf:type rdf:resource="resource22"/>
<info:contains>fromdisk1</info:contains>
<info:has_text_value>The location</info:has_text_value>
</rdf:Description>
<rdf:Description rdf:about="title2">
<rdf:type rdf:resource="resource12"/>
<info:contains>fromdisk2</info:contains>
<info:has_text_value>xyz</info:has_text_value>
</rdf:Description>
</rdf:RDF>
有很多在线资源可以向您展示如何在Jena中读取和操作RDF数据。为了让您开始,这里有一种方法:
首先创建一个Model
并将数据加载到。我假设您的数据在文件./rdf/test.rdf
:中
Model m = FileManager.get().loadModel( "./rdf/test.rdf" );
现在创建一个表示title2
:的资源
String NS = "http://example.org/data/test#";
Resource title2 = m.getResource( NS + "title2" );
现在列出资源的属性:
for (StmtIterator i = title2.listProperties(); i.hasNext(); ) {
Statement s = i.next();
System.out.println( "title2 has property " + s.getPredicate() +
" with value " + s.getObject() );
}
或者,创建一个属性对象来访问info:contains
属性:
Property contains = m.getProperty( NS + "contains" );
System.out.println( "title2.contains = " + title2.getProperty( contains )
.getObject();