我有一堆时态数据,我想将其转换为 RDF 格式。有没有可以接受的方法?
应以某种方式转换为 RDF 格式的表格数据示例:
| Name | Date | Salary |
-----------------------------------
| John | Jan 2012 | 3,244 |
| John | Feb 2012 | 4,012 |
| John | Mar 2012 | 3,112 |
找到了一种方法来做到这一点,但是它相当笨重并且引入了非常大的词汇量。假设语法(主语、谓语、宾语)
(JohnJan2012, date, Jan 2012)
(JohnJan2012, name, John)
(JohnJan2012, salary, 3244)
有谁知道更好的方法吗?
您可以在此处使用 bNodes 并使用 Turtle 语法执行以下操作:
@prefix xsd: <http://www.w3.org/2001/XMLSchema#> .
:john :salary [
:amount "3244.0"^^xsd:decimal;
:date "2012-01-01T00:00:00"^^xsd:datetime;
] .
:john :salary [
:amount "4012.0"^^xsd:decimal;
:date "2012-02-01T00:00:00"^^xsd:datetime;
] .
我在这里为您提供的这些示例创建两条记录。
[]
语法创建一个空白节点,它基本上是一个没有名称 (URI) 的节点。从示例中的每个空白节点中,我们都有两条信息:日期和金额。
此外,如果您想稍后使用 SPARQL 查询数据,请确保使用有效的
xsd:datetime
日期。
有关在 RDF 中表示时间的不同方式的更全面讨论,请参阅 Ian Davis 的 关于此主题的优秀博客文章在 RDF 中表示时间系列