- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 Apache Jena 读取一个 RDF 文件,它看起来像这样:
<rdf:RDF
xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
xmlns:dcat="http://www.w3.org/ns/dcat#"
xmlns:skos="http://www.w3.org/2004/02/skos/core#"
xmlns:foaf="http://xmlns.com/foaf/0.1/"
xmlns:owl="http://www.w3.org/2002/07/owl#"
xmlns:dct="http://purl.org/dc/terms/"
xmlns:dctypes="http://purl.org/dc/dcmitype/"
xmlns:rdfs="http://www.w3.org/2000/01/rdf-schema#">
<dcat:Catalog rdf:about="http://uri/">
<dcat:dataset>
<dcat:Dataset rdf:about="http://url/bop2262008322pdf/">
<dct:publisher>
<foaf:Organization>
<foaf:homepage rdf:resource="http://url"/>
<dct:title xml:lang="ca">Neme</dct:title>
</foaf:Organization>
</dct:publisher>
<dcat:distribution>
<dcat:Download>
<dct:modified rdf:datatype="http://www.w3.org/2001/XMLSchema#date"
>2012-11-09T16:23:22</dct:modified>
<dct:format>
<dct:IMT>
<rdfs:label>pdf</rdfs:label>
<rdf:value>application/pdf</rdf:value>
</dct:IMT>
</dct:format>
<dcat:accessURL>http://url/</dcat:accessURL>
</dcat:Download>
</dcat:distribution>
<dcat:keyword xml:lang="ca">Keyword 2</dcat:keyword>
<dcat:keyword xml:lang="ca">Keyword</dcat:keyword>
<dct:creator>Creator</dct:creator>
<dct:modified rdf:datatype="http://www.w3.org/2001/XMLSchema#date"
>2013-04-16T12:27:14</dct:modified>
<dct:issued rdf:datatype="http://www.w3.org/2001/XMLSchema#date"
>2011-03-02T10:28:58</dct:issued>
</dcat:Dataset>
</dcat:dataset>
<dct:license rdf:resource="http://creativecommons.org/licenses/by/3.0/"/>
<dct:title xml:lang="es">Example</dct:title>
<dct:title xml:lang="ca">Example</dct:title>
</dcat:Catalog>
</rdf:RDF>
我基本上想获取每个 dcat:dataset
资源和相应的语句。但我无法弄清楚如何从特定命名空间和本地名称(在本例中为 dcat:dataset
)遍历所有资源。我想只有通过包含属性才能找到资源。但是 namespace dcat
似乎不受 Jena 支持。我在词汇表中找不到它。
最佳答案
在大多数情况下,本地名称和前缀只在序列化中起作用。尽管 RDF/XML 文件包含
<dcat:Catalog rdf:about="http:/uri/>
<dcat:dataset>
<dcat:Dataset rdf:about="http://url/bop2262008322pdf/">
…
您的 RDF 图实际上包含三元组:
<http:/uri/> <http://www.w3.org/ns/dcat#dataset> <http://url/bop2262008322pdf/>
这是一个重要的区别,因为序列化图可以使用不同的前缀并产生不同外观的输出。例如,您的 RDF/XML 文档可以另外具有前缀 dcatdata
:
<rdf:RDF
xmlns:dcatdata="http://www.w3.org/ns/dcat#data"
>
之后您的 RDF/XML 文档可能如下所示:
<dcat:Catalog rdf:about="http:/uri/>
<dcatdata:set>
<dcat:Dataset rdf:about="http://url/bop2262008322pdf/">
…
因此,您不应该依赖于特定的前缀,而应该通过 IRI 访问资源。在这种情况下,听起来您想要使用 rdf:type dcat:Dataset
和将这些资源作为主题的语句来检索资源。使用 Jena 模型和资源 API 可以很容易地做到这一点。这是一个例子:
import com.hp.hpl.jena.rdf.model.Model;
import com.hp.hpl.jena.rdf.model.ModelFactory;
import com.hp.hpl.jena.rdf.model.ResIterator;
import com.hp.hpl.jena.rdf.model.Resource;
import com.hp.hpl.jena.rdf.model.StmtIterator;
import com.hp.hpl.jena.vocabulary.RDF;
public class DCATExample {
public static void main(String[] args) {
final String dcat = "http://www.w3.org/ns/dcat#";
Model model = ModelFactory.createDefaultModel();
model.read( "data.rdf" );
Resource datasetType = model.getResource( dcat + "Dataset" );
ResIterator datasets = model.listSubjectsWithProperty( RDF.type, datasetType );
while ( datasets.hasNext() ) {
Resource dataset = datasets.next();
StmtIterator stmts = dataset.listProperties();
System.out.println( "* "+dataset );
while ( stmts.hasNext() ) {
System.out.println( "** "+stmts.next() );
}
}
}
}
这会产生这个输出:
* http://url/bop2262008322pdf/
** [http://url/bop2262008322pdf/, http://purl.org/dc/terms/publisher, -7ec508e8:13f14cb9040:-7ffd]
** [http://url/bop2262008322pdf/, http://www.w3.org/ns/dcat#distribution, -7ec508e8:13f14cb9040:-7fff]
** [http://url/bop2262008322pdf/, http://www.w3.org/ns/dcat#keyword, "Keyword 2"@ca]
** [http://url/bop2262008322pdf/, http://www.w3.org/ns/dcat#keyword, "Keyword"@ca]
** [http://url/bop2262008322pdf/, http://purl.org/dc/terms/creator, "Creator"]
** [http://url/bop2262008322pdf/, http://purl.org/dc/terms/modified, "2013-04-16T12:27:14"^^http://www.w3.org/2001/XMLSchema#date]
** [http://url/bop2262008322pdf/, http://purl.org/dc/terms/issued, "2011-03-02T10:28:58"^^http://www.w3.org/2001/XMLSchema#date]
** [http://url/bop2262008322pdf/, http://www.w3.org/1999/02/22-rdf-syntax-ns#type, http://www.w3.org/ns/dcat#Dataset]
关于rdf - 使用 Jena 迭代 RDF 文件中的特定资源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16939159/
来自 RDF Schema 1.1 2.4 rdfs:Datatype rdfs:Datatype is the class of datatypes. All instances of rdfs:D
我遇到了books ontology ,在 owl 的底部文档,我们有: A reservation has been made by a person for a boo
在 RDF/XML 文件中具有属性的订单是否重要?换句话说,以下两个相同吗? 1 2 2 1 最佳答案 是的,RDF 在数学上被定义为一组三元组,因此这些三元组在您使用
我刚开始学习 RDF,我的问题是: 空白节点的目的是什么? 例子: ex:John foaf:knows _:p1 _:p1 foaf:birthDate 04-21 这
让我们看看这个例子:http://dbpedia.org/page/Berlin “owl:sameAs”和“is owl:sameAs of”有什么区别 最佳答案 owl:sameAs 是一个对称属
许多数据集都有变化的历史。将历史数据作为关联数据提供可能是一个挑战。我正在考虑的一般情况是,数据集包含有关具有可以随时间变化的属性的事物的数据。一个例子可能是温莎城堡的历史:它过去有很多配置,但它仍然
我正在使用 MarkLogic 8.0-6.3 使用 sem:rdf-load 从 RDF 文件生成三元组时很少有三元组没有被创建。 我已经粘贴了 RDF 文件内容、生成的三元组和我用来加载文件的查询
在这里完成 RDF 新手,我正在努力理解如何创建合理且可重用的谓词。我问了我们公司的几位专家,但他们的谓词(被迫)通过复制对象是唯一的(例如 woman,has_a_bag,purse 与 woman
谁能给我一个 RDF 中具体化的简单例子?我想看看我是否理解正确。 例如,我提出以下案例 Tolkien -> wrote -> Lord of the rings /|\
我想对如下所示的合作伙伴关系进行建模,我以标记属性图的格式表示。 我想使用RDF语言来表达上面的图,特别是我想了解是否可以表达“loves”边的标签(这是一篇文章/信件的URI)。 我是RDF新手,我
我在构建 Project Gutenberg 目录的 SPARQL 查询时遇到困难(可在页面底部的 Gutenberg Feeds 获取)。我知道我对 SparQL/RDF 等如何工作缺乏了解。实际上
我正在用 RDF 创建一个 Material 集合。我遇到了两种处理度量单位的方法: 通过将描述性名称链接到 RDF 属性: prop:density prop:hasUnits "kg/m
RDF:Property 是否可以包含其他属性以及 rdf:range 和 rdf:domain。例如,您是否可以拥有以下内容: This is a member of
我对 RDF 和 RDF Schema (RDFS) 有点困惑。我读过一些文档,其中提到 rdfs 是为 RDF 定义词汇表。 根据这个定义,我可以说 RDFS 是像 OWL 或 Dublin Cor
rdf:resource、rdf:about 和 rdf:ID 之间在概念上有什么区别。我做了一些调查,但我还不清楚它们之间的区别。例如,第一次声明资源时是否使用rdf:ID,rdf:resource
这是rdf代码: 42 我需要得到号码 "42" .我试过这个: PREFIX soton: PREFIX skos: ?location skos:notation rdf:
关于语义网的初学者问题。 我有一个颜色知识库,其中包括相似的颜色、颜色修饰符(暗、亮、~ish 等)、颜色关系(更深、更亮)、颜色同义词等。我想弄清楚 RDF/OWL 是否是一个操作(主要是查询)这个
有什么办法可以加快 rdf 文件加载到 Sesame 中的速度吗?我有 N-triple 格式的文件,大小从几 MB 到几 GB。我已经尝试了 Sesame Cook Book 中的前三种方法,但无济
例如,这句话: "I give John a book." 使其成为一组三元组: I give John. John hasIndirect book. book count 1. 或者,它可以是:
在 RDF 图的 Turtle 序列化中,我有很多这样的三元组(很多个体,都有一个共同的类型值): :A a :b . :B a :b . :C a :b . :D a :b . # … :Z a :
我是一名优秀的程序员,十分优秀!